Correction of scaling mismatches in oligonucleotide microarray data
 Martino Barenco^{1, 2}Email author,
 Jaroslav Stark^{3, 1},
 Daniel Brewer^{2, 1},
 Daniela Tomescu^{1},
 Robin Callard^{1, 2} and
 Michael Hubank^{1, 2}
https://doi.org/10.1186/147121057251
© Barenco et al; licensee BioMed Central Ltd. 2006
Received: 09 November 2005
Accepted: 09 May 2006
Published: 09 May 2006
Abstract
Background
Gene expression microarray data is notoriously subject to high signal variability. Moreover, unavoidable variation in the concentration of transcripts applied to microarrays may result in poor scaling of the summarized data which can hamper analytical interpretations. This is especially relevant in a systems biology context, where systematic biases in the signals of particular genes can have severe effects on subsequent analyses. Conventionally it would be necessary to replace the mismatched arrays, but individual time points cannot be rerun and inserted because of experimental variability. It would therefore be necessary to repeat the whole time series experiment, which is both impractical and expensive.
Results
We explain how scaling mismatches occur in data summarized by the popular MAS5 (GCOS; Affymetrix) algorithm, and propose a simple recursive algorithm to correct them. Its principle is to identify a set of constant genes and to use this set to rescale the microarray signals. We study the properties of the algorithm using artificially generated data and apply it to experimental data. We show that the set of constant genes it generates can be used to rescale data from other experiments, provided that the underlying system is similar to the original. We also demonstrate, using a simple example, that the method can successfully correct existing imbalancesin the data.
Conclusion
The set of constant genes obtained for a given experiment can be applied to other experiments, provided the systems studied are sufficiently similar. This type of rescaling is especially relevant in systems biology applications using microarray data.
Background
Gene expression profiling using microarrays has become a popular technique in modern biochemical research. One of the commonest microarray platforms in use is the highdensity oligonucleotide array introduced by Affymetrix (Santa Clara, CA). In the Affymetrix system, biotinylated cRNA generated from the sample of interest is hybridised to the array and detected using fluorescentlylabelled streptavidin. A number of different expression summary algorithms are available to derive the concentration of each transcript from the intensity of fluorescence. These include MAS5 (Affymetrix) [1], RMA [2], MBEI [3, 4].
It is important to use the most accurate and precise methods for calculating gene expression levels from microarray data. MAS5, RMA and MBEI offer different solutions to this problem. On Affymetrix arrays, transcripts are represented by multiple (typically 11) pairs of 25mer oligonucleotides termed a probeset. One of each pair is a perfect match (PM) for the target and the other is a mismatch control (MM). In MAS5, signal values from MM oligonucleotides are subtracted from PM oligonucleotide signals (if the MM value is greater than the PM value, an "ideal mismatch" (IM) value is subtracted from the PM value). RMA and MBEI use only the perfect match signal. In MAS5 there is no attempt to correct nonlinearities in the signal intensity response resulting for example from different overall transcript concentrations. In other words, MAS5 treats microarrays individually in contrast to RMA and MBEI, which apply a rankingtype algorithm to arrive at a signal value, and require multiple microarrays. However, it is important to note that the nomalization steps applied at the probe level in both MBEI and RMA even out nonlinearities across microarray experiments, but do not correct them. The other distinctive characteristic of MAS5 is that anaysis of spikein data has shown it to be more accurate than the other methods cited [5, 6]. This higher accuracy, however, comes at the cost of a lower precision or higher variablity at low expression values. These differences in method result in differences in performance and a tradeoff between accuracy and precision. Researchers select their preferred expression summary algorithm depending on their particular experimental application.
To date, expression profiling has been largely limited to applications in class discovery or prediction (geared towards molecular diagnostics), and in relatively simple functional studies involving direct comparisons of microarrays. Increasingly however, there is a move towards the mathematical modelling of dynamic gene networks. These systems biology applications typically require a sequence of microarray measurements in time which are applied in conjunction with dynamical models. In this context, measurement accuracy is paramount otherwise it would be impossible to arrive at accurate solutions to kinetic parameter estimates, such as transcript degradation rates. Therefore in systems biology, the accuracy of the measurements takes precedence over other considerations such as their precision. The higher accuracy achieved by MAS5 makes it the method of choice for gene network modelling.
Systems biology applications also raise practical issues. Time course data collection is demanding on resources as replicate RNA samples must be isolated for each timepoint. Because of experimental variability, individual timepoints cannot be rerun separately. Rejection of data from outlier arrays in a time course experiment should therefore entail the replacement of the whole time course. In complex experimental systems this is often unfeasible on the grounds of both practicality and cost. Consequently there is a demand for methods for renormalising, and thus retaining, suboptimal arrays. These methods would benefit all microarray applications, but would be of particular importance where the data is applied in modeling contexts. In this paper we therefore concentrate on renormalisation of MAS5 generated data to more accurately reflect expression values.
Results and discussion
Our method supposes there exists a set of constant genes, i.e. genes whose expression levels are unaffected under the experimental conditions, and that these genes can be used to accurately normalize the data. This idea of using constant genes has already been proposed [10], it was however in the context of twocolour cDNA microarrays. Our method consists of identifying this set of constant genes in an iterative fashion. In a first step a set of constant genes is singled out on the basis of some dispersion criteria, we call this set the initial set. The genes belonging to this set are used to normalize the microarrays. In a subsequent step, a new set of unchanging genes is defined using the same criteria. Several such steps are performed in sequence until the set of constant genes is unchanged from one step to the next. At this point the method is said to have converged and the corresponding set of constant probe sets is used to rescale the whole experiment (for a thorough description see Methods section).
To study the properties of the method, we generated artificial data. This allowed us to explore its convergence, increase its efficiency and define criteria for detecting hypothetical (and unlikely) situations in which a set of constant genes is nonexistent. The results of these purely in silico explorations are described in the the first part of this section, the description of the setup is deferred to the methods section. In the second part, we apply the algorithm to real experimental data and show that it converges to a unique set of genes and that the set of constant genes can be reused with a different microarray dataset, provided that the tissues involved are sufficiently similar. We demonstrate, using a simple time course interpolation example, that the resulting rescaling does indeed correct imbalances in the data and compare these results with another popular normalization procedure (quantile normalization) and with RMAsummarized data.
In Silico explorations
Artificial data was generated for 10'000 genes on 7 microarrays, a small portion (5%) of these genes was set to be constant. The scaling of these data was then perturbed with varying severity and for each perturbation our rescaling algorithm was applied. This setup is thoroughly described in the Methods section.
Each individual run was assigned to one of the three following groups:

Good runs were those for which the size of the final set exceeded 100.

In contrast, poor runs were those for which the size of the final was less than or equal to 100.

In the special case where the algorithm failed to find a big enough (> 2) initial set, three genes known to be constant were forced into the initial set (recall that 5% of the genes were set to be constant). We call these helped runs.
For each run, we computed an accuracy index (see methods) indicating whether the artificially induced perturbations were accurately corrected. This index can take nonnegative values and must be as close to zero as possible. We also monitored the speed of convergence, i.e. the number of iterations steps the algorithm takes before convergence.
Artificial data: results
Helped runs constitute a special case. Despite starting with a high perturbation – which is why they need help in the first place – they end up being very similar to good runs with both a good accuracy and a large final set. The inclusion of genes known to be constant accelerates convergence so that helped runs converge within 5–7 iterations. Helped runs occur mainly when the perturbation is large. This demonstrates that feeding some known constant genes into the initial iteration is a good way to "seed" the algorithm and has the added bonus of speeding up the (already quick) process. With real data, standard housekeeping genes (Affymetrix identifier ranging from 20000_s _at to 20099_s _at on the U133 Array) can fulfill that role.
Although they might not end up in the final set, our experience is that the inclusion of some of these in the initial set does indeed set the algorithm onto the right path.
Poor runs were defined by setting a limit on the size of the final set. For these cases, it is easy to verify that the final set, on top of being small, has a small "basin of attraction". We perturbed the initial guess by removing and adding genes. This produced different final sets thereby confirming the poor quality of these runs. In contrast, good and helped runsproduced stable final sets (data not shown). Hence, poor quality is fairly easy to detect and can be remedied by supplying the algorithm with a small set of genes that are suspected of being constant, i.e. to create a "helped" run.
In the good and helped runs, the final set of constant genes contains around 400 genes. Hence, not all constant genes (recall that 500 of those were generated) are included in this final set. A less severe selection criterion would select more constant genes. The final set also includes a small number of genes (< 10) that were not expected to be constant. But, as the accuracy plot testifies, their presence does not have an adverse effect on the final result. With real data, the boundary between constant and nonconstant genes is blurry, and lightly downregulated genes are likely to be balanced by lightly upregulated ones. This hypothesis is also at the heart of the centralization algorithm presented in [11].
From this first series of simulations, we conclude that the quality of a run can simply be assessed by the size of the final set and that a good way to ensure fast and accurate convergence is to feed the starting set with genes known to be constant. In a real situation, standard housekeeping genes can be used to that effect.
Algorithm performance in the absence of constant genes
Experimental data
Cells from the human Tcell line (MOLT4) were submitted to ionising radiation of 5 Gy using a ^{137}Cs source. RNA was prepared and labelled using standard procedures. Affymetrix U133A microarrays were then run on biological triplicates of transcripts taken 2,4,6,8,10 and 12 hours after irradiation. Triplicates were also taken at 0 hours, i.e. just before irradiation. These 21 microarrays vary in average signal intensity, by this we mean that some are "darker" than others, indicating a lower transcript concentration. We will refer to this data set as the 5Gy experiment. Another set of chips were run under different conditions, the irradiation dose was smaller (1Gy) than in the previous time series (5Gy). Biological triplicates were taken 4, 8 and 12 hours after irradiation, the 0 hours microarrays were the same as in the 5Gy experiment, therefore there is a slight overlap between the two experiments. This dataset, consisting of 12 microarrays, will be referred to as the 1Gy experiment. The data was summarized with MAS5 using standard parameters.
5Gy experiment
We first applied the algorithm to the 5Gy experiment. As a measure of the variability of a gene, we used the second formula (5) given in the methods section and fixed the variability limit to 0.2 to match our estimation of the relative error. This condition was applied to each replicate separately (if a replicate failed, then the gene would be excluded from the constant set) rather than globally on the 21 microarrays.
Further conditions (denoted in the methods section equation (6) by C(i, A))were as follows:

To avoid including genes with a low expression and absent genes an upper limit of 0.001 was set on the detection pvalue provided by MAS5.

An upper limit on the signal value of the 0 hours microarray of the first replicate was set to 2000.
This limit empirically corresponds to the point where distortions in the upper range of the signal become apparent (see Figure 1).
Rescaling factors obtained by the recursive procedure (5Gy experiment)
sample 1  sample 2  sample 3  

0 hrs  1.00  0.99  0.97 
2 hrs  0.98  1.02  1.00 
4 hrs  1.04  1.01  0.98 
6 hrs  1.04  1.09  1.02 
8 hrs  1.00  1.22  1.16 
10 hrs  1.08  1.06  1.16 
12 hrs  1.03  1.03  1.06 
To test the stability of the final set, several further runs were performed using perturbed versions of the original data. To do this, we chose initial values of ${p}_{a}^{0}$ not equal to 1 (${p}_{a}^{0}$ is the initial perturbation coefficient, see methods). For example, ${p}_{a}^{0}$ = 1 + ε, where ε is a random variable uniformly distributed on (1/2,1/2). In all of these additional runs the algorithm converged to a very similar final set (the overlap was > 99% in each case), which confirms its robustness of the original set.
Original scaling factors obtained with MAS5
sample 1  sample 2  sample 3  

0 hrs  0.852  0.751  0.931 
2 hrs  0.667  0.949  1.925 
4 hrs  0.675  1.233  1.019 
6 hrs  0.882  1.797  1.732 
8 hrs  0.744  3.010  2.634 
10 hrs  1.121  1.232  2.364 
12 hrs  1.066  1.134  1.688 
As intended, the expression levels of the genes composing the constant set span a smaller range than the overall expression level measured on a microarray (Figure 4). Note that the majority of gene with signals below 20 are considered absent by the MAS5 algorithm.
1Gy experiment
Rescaling factors obtained by the recursive procedure (1Gy experiment)
Sample 1  Sample 2  Sample 3  

0 hrs  1.00  0.99  0.98 
4 hrs  1.00  1.03  1.02 
8 hrs  1.03  1.07  1.04 
12 hrs  1.01  1.04  1.06 
With respect to the 5Gy experiment, the quality of the microarrays used in this second experiment is more uniform, which results in rescaling factors that are closer to 1. Notice as well that the number of genes included in the constant set is larger: 1568 instead of 1194. This is also because in the 1Gy experiment there were less microarrays of lower quality, causing more genes in this experiment to pass the filtering step.
Lists of constant genes are reuseable
Of the 1568 genes flagged as constant in the 1Gy experiment, 826 are also in the the list of constant genes for the 5Gy experiment (hence 742 genes are included in the 1Gy list only and 368 in the 5Gy list only). Despite this incomplete overlap, we show below that the usage of such lists does not have to be restricted to the experiments from which they were extracted.
We found that calculating rescaling factors for the 1Gy data set using the list of 1194 genes identified though the 5Gy experiment produced values very similar to those obtained with the 1Gy data alone (Figure 5, right). The biggest absolute difference between the two sets of values occurs for the first sample microarray 4 hours after irradiation and is equal to 0.013 (the average of these absolute differences across all microarrays is equal to 0.005).
The same conclusion can be reached when the experiment roles are swapped. The rescaling factors for the 5Gy data obtained using the 1Gy set of constant genes are compared with the original values in Figure 5 (left plot) and the biggest absolute difference is 0.024 for the third replicate 2 hours after irradiation, the average of these absolute differences being equal to 0.007.
Therefore, provided that the experimental conditions are not too dissimilar (same cell line and treatment), we conclude that the list of constant genes obtained through a given experiment can be safely used to calibrate data obtained from another experiment.
Why is rescaling necessary?
The rescaling factors shown in Table 1 might seem small with respect to the measurement error that prevails in microarray experiments and they may have little impact in simple screening or comparisontype analyses. However, increasing numbers of microarray experiments are carried out in a systems biology context (see [12] for a short review), in which proper scaling of the data is crucial to obtain sound interpretations.
To illustrate this point, we performed a simple time course analysis. Intermediate points (at 2,4,6,8 and 10 hours) were "predicted" using a linear interpolation procedure on neighbouring time points, for each replicate and gene (Figure 6). Each plot shows the quartiles of relative interpolation error ((true value interpolated value)/true value) for the first and the second replicate, before (Figure 6A) and after rescaling (Figure 6B). Nonrescaled data is severely skewed, this is especially the case for those time points suffering from ascaling mismatch such as the one illustrated in figure 1 (replicate 2, 8 hours). Rescaling the data corrects for this mismatch: the interpolation errors are much more centered in the rescaled situation. We have used this rescaled data in a modeling context to predict targets of p53, an important transcription factor involved in the cell response to DNA damage [13].
We also compared our method to another popular normalization method: quantile normalization [14]. This normalization step is the one used in the RMA summary method, albeit at the probe level. We applied it instead to MAS5 summarized values and the results are shown in figure 6C. As can be readily seen from this example, quantile normalization fails to accurately correct for scaling imbalances in the data. Similarly, we performed the same interpolation analysis on RMAsummarized probelevel data (figure 6D). RMA does not perform well in this situation, we believe this is because the lesser quality microarrays have a deleterious effect on the whole dataset.
Conclusion
Inaccurate scaling of median range signal values can have significant deleterious effects on mathematical modelling of microarray data. Experimental correction of problematic arrays can be expensive and impractical. We have therefore developed a method for rescaling arrays to avoid the unnecessary loss of otherwise valid data. We present an algorithm designed to identify a set of constant genes in oligonucleotide microarray experiments. Applying this algorithm to artificially generated data allowed us to identify the conditions under which this set can be used for the correction of scaling mismatches. We applied the algorithm successfully to real experimental data and showed that the set of constant genes obtained for a given experiment can be generally applied, provided the systems studied are sufficiently similar. This type of rescaling is especially relevant, if not crucial, in modelling applications of microarray data.
Methods
Description of the algorithm
Let x_{i,a}be the signal for gene i as it is measured in microarray a. We hypothesise that this value can be decomposed as follows:
x_{i,a}= k_{ a }s_{i,a}exp(ε), (1)
where s_{i,a}is the "true" signal for gene i in microarray a (the value of the signal depends on the microarray as well, but for purely biological reasons). The third term exp(ε) is a multiplicative noise term, ε is a random variable identically distributed across all genes and microarrays with mean zero, and standard deviation typically around 0.15 – 0.20 which matches the average relative error (of 15% – 20%) generally observed in microarray data. The focus here is on the first component k_{ a }, which results from inaccurate normalisation. In other words, one wishes to find a rescaling factor p_{ a }such that
p_{ a }k_{ a }= 1.
Note that there is no "true" level for the signal, so that a more accurate formulation would be that one wishes to find p_{ a }such that p_{ a }k_{ a }= C for all microarrays a, where C is some userdefined constant. However, we will define a particular microarray r to be the reference (k_{ r }= 1) in order to retain the above formulation.
The proposed algorithm to determine the p_{ a }'s is simple, it assumes that there exists a set of genes U whose expression is unchanged across all microarrays:
U = {i : s_{i,a}= s_{ i }> 0 ∀ a}.
If U is known, an accurate estimate of p_{ a }can be obtained via a ratio of geometric averages for the relevant microarrays:
where #(U) denotes the number of elements in the set U. We show below that ${\tilde{p}}_{a}$ is a good approximation for p_{ a }:
Our aim is to determine U. To do this, we first determine a set of genes U_{1} which have a low "variability" $\mathcal{V}$. As a measure of variability, we could use the coefficient of variation, which is given by
where A is the set A = {1, ..., n} (the set of microarrays), x_{i,a}, a = 1, ..., n denotes n observations and ${\overline{x}}_{i}$ is the arithmetic mean of the x_{i,a}across all a's. We thus average the readings for a particular gene across several microarrays. However, because of the multiplicative context, it is preferable to use a geometric average, so that
where ${\overline{x}}_{i}^{g}$ is the geometric mean. We therefore define
U_{1} = {i : $\mathcal{V}$(i, A) <v_{*} $\mathcal{C}$ (i, A)},
where A is the set of microarrays and v_{*} is a parameter. $\mathcal{C}$ (i, A) is a boolean variable that denotes another condition (or set of conditions) on the i th gene and is not of direct concern here. For example, via $\mathcal{C}$ (i, A), we might try and avoid including in the set of constant genes those genes that are flagged absent by MAS5 throughout the experiment.
We then assume U_{1} is U and we use (2) to compute estimated rescaling factors ${\tilde{p}}_{a}$. The x_{i,a}'s can then be updated, but this is likely to modify the composition of the set constant genes so that we might have to perform a similar step again, therefore the set U has to be determined in an iterative fashion. The full description of the k th step is
1. Determine a putative set of "constant" genes using
U_{ k }= {i : (i, A, k  1) <v*, $\mathcal{C}$ (i, A)}. (6)
In the equation above, a parameter k  1 has been added to the function $\mathcal{V}$, to underline the fact that the coefficient of variation has to be determined with updated values of the signal.
2. Update the rescaling factors using
or (the formula is equivalent)
3. Update the signals using
or (again, equivalently)
The algorithm has converged at step m if U_{ m }and U_{m+1}are identical sets. To start the algorithm at k = 1 we require initial values ${x}_{i,a}^{0}$. These are given by
where we will typically fix ${p}_{a}^{0}$ = 1.
Several criteria have to be met for the algorithm to be reliable. First, one has to verify that the algorithm does converge: it has to find the final set U_{ m }and not wander aimlessly among the huge number of gene sets. Second, the convergence has to be reasonably quick and robust. Lastly, one wants to ensure that the final set of genes U_{ m }returned by the algorithm is indeed a set of constant genes. These conditions are difficult to verify analytically, which is why we resorted to numeric simulation. These simulations are presented in the Results and Methods section. A R script implementing the algorithm in the case of simple replication and no extra conditions has been included as supplementary material.
A set of constant genes can be used for rescaling
We want here to prove that (3) holds and in particular demonstrate that the approximation is a good one. Using (1) we have
We have k_{ r }= 1, the second ratio on the right hand side is equal to 1. Turning to the third term in (8), we see that its expectation can be written as
E (exp (ε)),
where
For the sake of this argument, we assume the relative errors for the gene expression measurements to be iid and equal to 20%. Applying the central limit theorem to (9), one can see that ε is Gaussian with parameters μ = 0 and a = (2 * 0.2)/$\sqrt{\#\left(U\right)}$. Thus, exp(ε) is lognormal with the same parameters. The expectation of a lognormal distribution is exp(μ + σ^{2}/2), hence
E (exp (ε)) = exp(0 + 0.08/#(U)).
The expectation of this third term is slightly bigger than 1 but since the size on the set U is typically in the hundreds, the difference is considerably less than 1%. Replacing in (8) we thus have, as required
where the approximation is more than good enough for our practical purposes.
In silico explorations
Artificial data generation
We generated artificial signals for 10,000 genes on 7 microarrays using the following procedure. For the i th gene in the a th microarray we generate observed signals x_{i,a}according to
x_{i,a}= k_{ a }s_{i,a}exp(ε),
The first term k_{ a }is the scaling mismatch we want the algorithm to uncover. The third term exp(ε) is an error term, where ε is set to be Gaussian with mean zero and standard deviation 0.2. The second term s_{i,a}is generated using
where $\mathcal{G}$ is a Gaussian random variable with mean 1.5 and standard deviation 0.4. Furthermore, a small portion of these genes (5% or 500) are set to be constant, that is for i ε U, we have s_{i,a}= s_{ i }.
Alhough real experiments yield more complex expression patterns, this artificial data is amply sufficient to capture the main features of our method.
To simulate the scaling mismatches k_{ a }, we generate them by
k_{ a }= 1 + K(u  0.5), (10)
where u is a random variable uniformly distributed on the unit interval and K is a parameter capturing the severity of the mismatch. Without loss of generality, we set k_{1} = 1 because choosing an arbitrary reference array is required by our method.
We generated 191 different datasets and ran the algorithm on each of them. Each dataset differed from the others by the choice of the constant K in (10). The 191 values for K ranged uniformly between 0 and 1.9.
Each run was then assigned to one of the following three groups on the basis of the size of the final set U_{ m }(where the index m denotes the number of steps it took to the algorithm to converge):

Good runs were those for which the size of the final set U_{ m }exceeded 100.

In contrast, poor runs were those for which the size of U_{ m }was less than or equal to 100.

In the special case where the algorithm failed to find a big enough (> 2) initial set U_{1}, three genes known to be constant were forced into the initial set (recall that 5% of the genes were set to be constant). We call these helped runs.
For each run r, we computed an accuracy index using
where p_{ a }is the rescaling factor recovered from thealgorithm. Ideally, we want the rescaling factors p_{ a }to perfectly compensate the scaling factors k_{ a }so that p_{ a }k_{ a }= 1. Consequently, the accuracy index above, which can take nonnegative values, must be as close to zero as possible. We also monitored the speed of convergence i.e. the number of iterations steps m the algorithm takes before convergence.
Availability
An R script implementing the algorithm in the case of simple replication and no extra conditions has been included as additional file 1 (rescale.R). The data is available in Array Express (accession number EMEXP549).
Declarations
Acknowledgements
Part of the analyses and graphs presented in this article were produced using the Bioconductor package under R, in particular the "affy" library [15, 16]. M. Barenco and D. Tomescu are supported by an Exploiting Genomics Initiative grant from the BBSRC, Ref.:39/EGM16102. D. Brewer holds a CHRAT studentship by the ICH. The authors would like to thank the reviewers for their useful remarks.
Authors’ Affiliations
References
 Affymetrix: Affymetrix Microarray Suite User Guide, version 5. Affymetrix, Santa Clara, CA; 2001.Google Scholar
 Irizarry RA, Bolstad BM, Collin F, Cope LM, Hobbs B, Speed TP: Summaries of Affymetrix GeneChip probe level data. Nucleic Acids Res 2003, 31(4):el5. 10.1093/nar/gng015View ArticleGoogle Scholar
 Li C, Hung Wong W: Modelbased analysis of oligonucleotide arrays: model validation, design issues and standard error application. Genome Biol 2001, 2(8):RESEARCH0032.PubMed CentralPubMedGoogle Scholar
 Li C, Wong WH: Modelbased analysis of oligonucleotidearrays: expression index computation and outlier detection. Proc Natl Acad Sci U S A 2001, 98: 31–6. 10.1073/pnas.011404098PubMed CentralView ArticlePubMedGoogle Scholar
 Ploner A, Miller LD, Hall P, Bergh J, Pawitan Y: Correlation test to assess lowlevel processing of highdensity oligonucleotide microarray data. BMC Bioinformatics 2005, 6: 80. 10.1186/14712105680PubMed CentralView ArticlePubMedGoogle Scholar
 Choe SE, Boutros M, Michelson AM, Church CM, Halfon MS: Preferred analysis methods for Affymetrix GeneChips revealed by a wholly defined control dataset. Genome Biol 2005, 6(2):R16. 10.1186/gb200562r16PubMed CentralView ArticlePubMedGoogle Scholar
 Kepler TB, Crosby L, Morgan KT: Normalization and analysis of DNA microarray data by selfconsistency and local regression. Genome Biol 2002, 3(7):RESEARCH0037. 10.1186/gb200237research0037PubMed CentralView ArticlePubMedGoogle Scholar
 Held GA, Grinstein G, Tu Y: Modeling of DNA microarray data by using physical properties of hybridization. Proc Natl Acad Sci U S A 2003.Google Scholar
 Naef F, Socci ND, Magnasco M: A study of accuracy and precision in oligonucleotide arrays: extracting more signal at large concentrations. Bioinformatics 2003, 19(2):178–84. 10.1093/bioinformatics/19.2.178View ArticlePubMedGoogle Scholar
 Tseng GC, Oh MK, Rohlin L, Liao JC, Wong WH: Issues in cDNA microarray analysis: quality filtering, channel normalization, models of variations and assessment of gene effects. Nucleic Acids Res 2001, 29(12):2549–57. 10.1093/nar/29.12.2549PubMed CentralView ArticlePubMedGoogle Scholar
 Zien A, Aigner T, Zimmer R, Lengauer T: Centralization: a new method for the normalization of gene expression data. Bioinformatics 2001, 17(Suppl 1):8323–31.View ArticleGoogle Scholar
 Stark J, Callard R, Hubank M: From the top down: towardsa predictive biology of signalling networks. Trends Biotechnol 2003, 21(7):290–3. 10.1016/S01677799(03)001409View ArticlePubMedGoogle Scholar
 Barenco M, Tomescu D, Brewer D, Callard R, Stark J, Hubank M: Ranked predictions of p53 targets using Hidden Variable Dynamic Modelling (HVDM). Genome Biology 2006, 7(3):R25. 10.1186/gb200673r25PubMed CentralView ArticlePubMedGoogle Scholar
 Bolstad BM, Irizarry RA, Astrand M, Speed TP: A comparison of normalization methods for high density oligonucleotide array data based on variance and bias. Bioinformatics 2003, 19(2):185–93. 10.1093/bioinformatics/19.2.185View ArticlePubMedGoogle Scholar
 Gautier L, Cope L, Bolstad B, Irizarry R: affy – Analysis of Affymetrix GeneChip data at the probe level. Bioinformatics 2004, 20(3):307–15. 10.1093/bioinformatics/btg405View ArticlePubMedGoogle Scholar
 Gentleman RC, et al.: Bioconductor: open softwaredevelopment for computational biology and bioinformatics. Genome Biol 2004, 5(10):R80. 10.1186/gb2004510r80PubMed CentralView ArticlePubMedGoogle Scholar
Copyright
This article is published under license to BioMed Central Ltd. This is an Open Access article distributed under the terms of the Creative Commons Attribution License (http://creativecommons.org/licenses/by/2.0), which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.