Time-of-flight mass spectrometers (TOFMSs) measure the abundance of ions in an analyte as a function of the time required for those ions to travel from an ion source to an ion detector that is located at a fixed distance from the ion source. Ions from the ion source are subjected to a short acceleration pulse by applying a voltage between the ion source and an acceleration electrode. The kinetic energy imparted to an ion is proportional to the charge on that ion and the acceleration voltage. The velocity of the ions after acceleration is determined by the acceleration voltage and the mass-to-charge ratio of the ions. Hence, the time of flight (TOF) between the ion source and the detector is a measure of the mass-to-charge ratio of the ions. The ion detector converts an ion impact to an electrical pulse. The spectrum produced by TOFMSs is the charge received by the ion detector as a function of time measured from the time of the acceleration pulse.
The low abundance and statistical nature of the ion impact response necessitate that the spectra from a large number of single pulses are combined to provide the final spectrum for a sample that is being analyzed. For any given application, there is a maximum TOF of interest. In the following discussion, the reciprocal of this TOF will be referred to as the “reference rate”. If the source is pulsed at a rate less than or equal to the reference rate, all of the ions of interest from any given packet will be detected prior to ions from a subsequent pulse arriving at the ion detector. The reference rate is the fastest rate at which the source can be pulsed without having ions of interest from one pulse reaching the detector at a time after ions from a previous pulse have not yet reached the detector.
The time to acquire a spectrum using the reference rate can be too long for many applications. If the analyte is changing over time, the analysis needs to be completed in a time that is much less than the time the analyte evolves. Even in the case of relatively stable samples, there is a limit to the time available on the TOFMS.
One method for decreasing the time needed to acquire a spectrum utilizes a scheme in which the ion source is pulsed at an average rate much higher than the reference rate. In this system, an ion reaching the ion detector could have resulted from any one of a number of pulses. By randomly varying the interpulse interval, the identity of the pulse giving rise to the ion may be determined with high accuracy.
Denote the ions that arrive from a single ion pulse within the range of allowed times of flight as a “transient”. If the source is pulsed at a rate less than or equal to the reference rate, the transients do not overlap, and hence, the launching pulse corresponding to each detected ion is known, and the TOF is the difference in time between the time of the pulse and the time at which the ion was detected. Processing the data from transients to arrive at TOF values for each ion is then relatively simple; however, the data acquisition rate is limited by the number of ions that can be launched in a packet and the TOF of the slowest ion species of interest.
The number of ions per packet is constrained by the available ion sources. In addition, the ion density must not be so great as to have the ions interacting with each other in a manner that alters the TOF of the individual ions or causes the packet to expand so that ions are lost.
There are applications in which the number of transients per unit time must be increased above the reference rate. For example, experiments in which the sample changes significantly in a time that is less than the time needed to collect sufficient impacts at the reference rate pose significant challenges if the TOFMS is limited to the reference rate.
If the TOFMS is operated at a rate above the reference rate, the transient responses will overlap. In this case, the pulse that gave rise to any given ion hitting the detector is not uniquely known from the time of arrival of the ion at the ion detector. For example, an ion striking the detector could be a fast moving ion from the last pulse or a slow moving ion from an earlier pulse. One method for generating a spectrum from such overlapping frames is disclosed in U.S. Pat. No. 8,080,782. In this method, the launching pulses are provided at variable intervals about some predetermined interval that is much shorter than the reference period. An algorithm that makes use of the random nature of the pulses is then used to generate the TOF spectrum by a method that will be discussed in more detail below. For the purposes of the present discussion, it is sufficient to note that the computational workload presented by this algorithm is significant. As a result, the time needed to actually generate a spectrum is much longer than the time needed to accumulate sufficient detector hits.
In applications in which the final spectrum is all that is required, the computations can be performed “off-line”. Hence, the spectrum acquisition time can be significantly improved as measured by the time needed to acquire the data on the TOFMS and the temporal evolution of rapidly evolving spectra can be more closely followed.
There are applications, however, in which the spectrum, or a reasonable approximation thereof, must be available in a time that is less than the processing time of the algorithm discussed above. Consider an experiment in which the sample that is being analyzed is changing with time in a manner that a component of interest is detected during the course of the experiment. When the component appears, the experimental protocol is to be changed. For example, if the component is detected with a TOFMS, a spectrum having sufficient accuracy to detect the component of interest must be available before the component disappears. In this case, the experiment cannot wait for the off-line processing discussed above. Accordingly, a method for providing a reasonable approximation to the final TOFMS spectrum with a minimal time delay is needed.
The present invention includes a spectrometer and a method for operating the same. The spectrometer includes an ion source that emits packets of ions and an ion detector that detects ions. The spectrometer also includes an event extractor, and a streaming processor. The event extractor generates a ion event record corresponding to each of the detected ions, the ion event record including an intensity associated with that detected ion and one or more aliases for that detected ion. The streaming processor receives the ion event record, stores a TOF spectrum, and updates that TOF spectrum for each alias in each received ion event record, the updates depending on a probability for each alias in each received ion event record and the intensity in that ion event record. The streaming processor stores the received ion event records in a buffer together with a timestamp associated with each received ion event record.
In one aspect of the invention, the streaming processor removes one of the ion event records from the buffer when the timestamp associated with that ion event record indicates that the ion event record is an expired ion event record. The streaming processor removes contributions to the TOF spectrum from the expired ion event record when the expired ion event record is removed from the buffer.
In another aspect of the invention, the TOF spectrum includes a memory array having a plurality of entries, each entry corresponding to a different possible TOF value for ions detected by the detector. The probabilities of all the aliases in one of the ion event records are set to be equal if all entries in the memory array corresponding to the aliases in that one of the ion event records are zero. The probability for each alias in one of the ion event records is proportional to a corresponding entry in the memory array if any of the aliases in that one of the ion event records corresponds to a memory entry in the memory array that is non-zero.
In a still further aspect of the invention, the ion source emits pulses in a pattern that ensures that contributions to the TOF spectrum resulting from incorrect aliases are substantially uniform.
In another aspect of the invention, the streaming processor discards an ion event record after the streaming processor removes the contributions from that ion event record from the TOF spectrum.
In yet another aspect of the invention, the streaming processor treats an ion event record whose contribution has been removed from the TOF spectrum as a new ion event record after the streaming processor removes the contributions of that ion event record from the TOF spectrum.
The manner in which the present invention provides its advantages can be more easily understood with reference to
The timing of the electrical pulses is controlled by a controller 16 via a pulse source 14. Controller 16 records the time at which each pulse is generated by accessing a clock 19. An event extractor 20 receives the output of ion detector 18 and records the time at which each detection event occurs provided the output of ion detector satisfies some detection criterion such as having a signal intensity that exceeds some threshold value. Other detection criteria will be discussed below. Event extractor 20 generates an ion event record for each detected ion. The contents of this record will be discussed in detail below. For the purposes of this discussion, it is sufficient to note that the record includes the possible times of flight that are consistent with the pulse timing and the amplitude of the signal from the ion detector.
The event records are input to a streaming processor 21 which maintains a running estimate of the TOF spectrum. The estimate provides an amplitude as a function of time of flight. The amplitudes are weighted sums of the amplitudes in the event records. The spectrum is stored in a memory array in which each memory location has weighted sums generated from the event records corresponding to a TOF associated with that memory location. The new records are used to update the memory array in a manner that will be discussed in more detail below. After being used to update the memory array, the records are input to a FIFO buffer 22 with a timestamp. Ion event records that are older than a predetermined value are said to have expired. Ion event records are output from the FIFO as the ion event records expire. The contents of each retrieved expired ion event record are then used to update the memory array by removing the contribution of that expired ion event record from the current contents of the memory array such that the memory array contains an estimate of the TOF spectrum based on ion event records spanning a specified range of times.
The contents of the ion event records will now be explained in more detail with reference to
Each event record includes the possible aliases for that event. Each event record also includes a probability associated with each of the aliases. Streaming processor 21 assigns the probabilities for each alias based on the running estimate of the TOF spectrum.
To simplify the following discussion, it will be assumed that each ion detection event occurs at a single time. That is, the ion detector output is digitized by an analog-to-digital converter that operates at a defined clock rate. In the following discussion, it will be assumed that the detection event spans only one time bin, i.e., the events shown at 32 each occur in a time that is less than one period of this clock. As a result, it will be assumed that each alias has a unique TOF value. The manner in which events that span multiple time bins are handled will be discussed in more detail below.
Denote the contents of the spectrum memory array by S(i). The index, i, denotes a possible time of flight value. Hence, S(A) denotes the amplitude associated with the time of flight represented by an alias, A. Consider the memory array when an ion event record having M aliases, Ai . . . AM is to be processed by streaming processor 21. In general the probability associated with each alias is
Here, M is the number of aliases in the event record. In the beginning, all of the S(i) will be zero. In this case, there is insufficient data to make the assignment based on the contents of S(i). In this “ 0/0” case, Pi=1/M for i=1 to M. That is, all aliases are assumed to have equal probability.
Once the probabilities are assigned to an ion event record, the streaming processor updates the spectrum array. Denote the amplitude of the detector signal associated with the ion event record by I. Then the spectrum memory array is updated by adding I*Pj to S(Aj) for j=1 to M. The ion event record is then input to FIFO buffer 22 and output for additional post processing
When the ion event record emerges from FIFO buffer 22 and re-enters streaming processor 21, the spectrum memory array is updated to remove the contribution of the old event from the spectrum by subtracting I*Pj from S(Aj) for j=1 to M. The event record is then either discarded or re-processed as described below.
In the above-described embodiments, the output of the ion detector was digitized at some ADC clock rate and each event spanned only one clock period. In practice, each ion detection event spans a plurality of ADC clock periods. Refer now to
The cumulative TOF spectrum S(T) at the time ion event 51 is detected is shown at 60. Denote the area under S(T) for the time values from Tn to Tn+K−1 by Wn, where n runs from 1 to 3. The probability assigned to alias, An, is Pn=Wn/D, where D=ΣWn, for n=1 to 3. The alias, An, is an array of K intensity values, In,j, each value corresponding to the intensity of the output of the ion detector in a corresponding one of the clock periods, which can be written explicitly as In,j, where j runs from Tn to Tn+K−1. Given this notation, the TOF spectrum is then updated for each alias in this event as follows:
S(j)→S(j)+Pn*In,j
for j=Tn to Tn+K−1.
It should be noted, however, that other methods for dealing with ion detector events that span multiple ADC clock periods could be utilized. For example, the output of the ion detector could be treated as an event that occurs at the average time value of the pulse shown at ion event 51 in
In another aspect of the invention, the detector output is blanked during the period of time around the rise and fall of the ion pulse signal that is applied to the ion source rises and falls to prevent electrical interference from the pulse generator from generating spurious signals from the ion detector.
The above-described embodiments utilize a non-uniform pulsing scheme to drive the ion source. Every event record may have a plurality of aliases. If the event was the result of a single ion striking the detector, one of these is the true TOF and the others are not. The aliases that are not the true TOF will be referred to as the “incorrect aliases” in the following discussion. The pulsing scheme is chosen such that the distribution of TOF values for the incorrect aliases is substantially uniform. In this case, the incorrect aliases form a substantially uniform background when these aliases are added into the spectrum memory array with equal probabilities. In one aspect of the invention, pseudo-randomly computed firing intervals are used to trigger the ion source. On average the source is fired at a rate that is significantly greater than the reference rate discussed above. However, the intervals between firings varies randomly about this reference period.
For the purposes of this discussion, the distribution of incorrect aliases is defined to be “substantially uniform” if any peaks in the TOF spectrum that result from incorrect aliases are less than the intensity of the lowest intensity correct alias peak that is to be detected. In general, there is no minimum detection threshold that is dictated by the particular experiment being run on the TOFMS. If any non-uniformities in the incorrect alias spectrum are below this threshold, the substantially uniform criterion is defined to be met.
The assignment of probabilities based on the running content of the spectrum memory array leads to a better estimate of the correct spectrum than would be obtained by assigning equal probabilities to all of the aliases. If each incoming ion event record is assigned equal probabilities, the contributions corresponding to each of the correct aliases constructively add while the remaining aliases generate a substantially uniform noise floor. This noise floor can obscure weaker peaks in the spectrum. By utilizing the running spectrum to compute the probabilities, the noise floor is lowered and the true alias locations responses are enhanced.
Given the events that were used to generate the spectrum, the noise floor can be iteratively lowered further if there is sufficient time available and a better estimate of the spectrum is needed. In one aspect of the invention, the iterative processing is performed by cycling the update algorithm using the stored events in FIFO buffer 22 multiple times before events are discarded due to aging.
Consider an event that has just been received from FIFO buffer 22 because it has expired. In the normal processing discussed above, the contributions of this event to the memory array are subtracted from the memory array and the event is discarded. In the iterative processing algorithm, instead of discarding the event, the event is treated as a new event from event extractor 20. The aliases of the event are assigned new probabilities based on the current contents of the memory array. The memory array is then updated to reflect the “new” event with the new probabilities, and the “new event” is re-input to FIFO buffer 22. When all of the events in FIFO buffer 22 have been reprocessed in this manner, one iteration will have been completed. The updated spectrum at the end of this iteration will be a better approximation to the actual TOF spectrum. The process can be repeated to further improve the approximation to the actual TOF spectrum.
While the above described iteration is performed in the streaming processor, embodiments in which the iteration is performed off-line by copying the events that went into the FIFO and the state of the spectrum memory array can also be constructed.
A hybrid system in which one iteration is effectively performed during the normal processing can also be constructed as follows. Assume that streaming processor 21 can accommodate twice the rate of events as the rate generated by event extractor 20. Each ion event record includes an indication as to whether or not it has been recycled. Events enter streaming processor 21 in the same manner as discussed above. Events from FIFO buffer 22 also enter streaming processor 21 and are processed as discussed above with reference to the iterative process. That is, the TOF contributions for each event from FIFO buffer 22 are first subtracted from the TOF spectrum. If the ion event record has not been recycled once, the ion event record is processed in the same manner as an ion event record from event extractor 20, and the ion event record is marked as having been recycled. When an ion event record that has been recycled exits FIFO buffer 22, that ion event record's contribution to the TOF spectrum is removed and the ion event record is discarded. This embodiment requires twice the FIFO buffer size as an embodiment without the built in recycling. While this hybrid system has been described in terms of one round of recycling, a system that utilizes multiple rounds of recycling can also be constructed. In such a system, the ion event records include a count of the number of times an ion event record has been processed through the streaming processor. Alternatively, the events can be recycled until the time span over which a given event is utilized exceeds some predetermined time.
As noted above, the event extractor generates the event records from the output of the ion detector. In general, the ion detector outputs a signal as a function of time that spans a finite range of TOF bins. In some cases, two ions will strike the ion detector at times that are separated by less than the width of the ion detector signal for one ion. In the simplest embodiment of an ion detector for use in the present invention, such multiple events are treated as a single ion striking the ion detector in which the event has a duration that extends for multiple ADC clock cycles as described above. Alternatively, the signal from the ion detector could be fitted to a multiple ion model and the intensities and times of arrival of the individual ions estimated.
The above-described embodiments utilize a FIFO buffer for storing the ion events records that were used to update the TOF spectrum until those ion event records expire. Since ion event records typically expire in the order in which the ion event records enter the buffer, a FIFO buffer is particularly well adapted for the ion event record storage, since the entire buffer does not need to be searched for expired events. However, other forms of storage buffer could be utilized in conjunction with a search strategy for finding the expired ion event records.
The above-described embodiments of the present invention have been provided to illustrate various aspects of the invention. However, it is to be understood that different aspects of the present invention that are shown in different specific embodiments can be combined to provide other embodiments of the present invention. In addition, various modifications to the present invention will become apparent from the foregoing description and accompanying drawings. Accordingly, the present invention is to be limited solely by the scope of the following claims.