US20180074096A1 - Recommending measurements based on detected waveform type - Google Patents
Recommending measurements based on detected waveform type Download PDFInfo
- Publication number
- US20180074096A1 US20180074096A1 US15/262,406 US201615262406A US2018074096A1 US 20180074096 A1 US20180074096 A1 US 20180074096A1 US 201615262406 A US201615262406 A US 201615262406A US 2018074096 A1 US2018074096 A1 US 2018074096A1
- Authority
- US
- United States
- Prior art keywords
- classification
- classifier
- classifiers
- waveform
- test
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01R—MEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
- G01R13/00—Arrangements for displaying electric variables or waveforms
- G01R13/20—Cathode-ray oscilloscopes
- G01R13/22—Circuits therefor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F18/00—Pattern recognition
- G06F18/20—Analysing
- G06F18/21—Design or setup of recognition systems or techniques; Extraction of features in feature space; Blind source separation
- G06F18/214—Generating training patterns; Bootstrap methods, e.g. bagging or boosting
- G06F18/2148—Generating training patterns; Bootstrap methods, e.g. bagging or boosting characterised by the process organisation or structure, e.g. boosting cascade
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01R—MEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
- G01R13/00—Arrangements for displaying electric variables or waveforms
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01R—MEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
- G01R13/00—Arrangements for displaying electric variables or waveforms
- G01R13/02—Arrangements for displaying electric variables or waveforms for displaying measured electric variables in digital form
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01R—MEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
- G01R23/00—Arrangements for measuring frequencies; Arrangements for analysing frequency spectra
- G01R23/16—Spectrum analysis; Fourier analysis
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F18/00—Pattern recognition
- G06F18/20—Analysing
- G06F18/24—Classification techniques
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N20/00—Machine learning
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N20/00—Machine learning
- G06N20/20—Ensemble learning
-
- G06N7/005—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N7/00—Computing arrangements based on specific mathematical models
- G06N7/01—Probabilistic graphical models, e.g. probabilistic networks
-
- G06N99/005—
Definitions
- This disclosure is directed to a system and methods for oscilloscope operation, and, more particularly, to a system and methods for detecting input waveform types and suggesting corresponding measurement settings for the oscilloscope.
- Test and measurement systems are designed to receive signal inputs, sample the signals, and display the result as a waveform.
- Various settings can be employed to control the manner of sampling, the nature of the samples taken, and the manner in which the waveform is displayed.
- Some advanced test and measurement systems include large numbers of potential control settings, and many such settings are only useful for specific input types. Accordingly, advanced models can inundate the user with choices, while making relevant settings exceedingly difficult to find.
- Embodiments of the invention address these and other issues.
- Embodiments of the disclosed subject matter include an oscilloscope configured to employ machine learning to classify incoming waveforms and/or attached buses and suggest measurements or other actions based on the classification.
- the oscilloscope undergoes a learning phase, where a plurality of classifiers receive training data representing particular waveforms or buses along with known classifications.
- the classifiers are applied to the training data and corrected when classifications output by the classifiers are incorrect in light of the known classifications.
- Confidence thresholds can also be stored for each classifier.
- Corresponding models are generated for each classifier, and suggested measurements and/or actions are added to each model. Further, feature selection may be employed on each classifier to reduce a set of classifier inputs by removing inputs that are not useful for the corresponding classification.
- Cross validation may also be employed to increase the accuracy of the classifiers.
- Such machine learning may occur for each manufactured oscilloscope or may occur for a master oscilloscope, with the results loaded into a plurality of oscilloscope at the point of manufacture.
- the oscilloscope receives incoming waveforms and applies each classifier to the incoming waveform.
- Each classifier returns a confidence value for a corresponding classification. If a single classifier returns a confidence value in excess of the classifier's confidence threshold, then the waveform has been properly classified.
- the classification is forwarded to a recommender, which obtains the model associated with the classification and implements any suggested measurements or actions.
- a test and measurement instrument includes an input port configured to receive measurement data, and a processor coupled to the input port.
- the processor is configured to apply a plurality of classifiers to the measurement data to determine a classification for the measurement data.
- the processor also selects a model corresponding to the classification, where the model corresponds to suggested measurements. Further, the processor configures the test and measurement instrument to employ the suggested measurements corresponding to the selected model when capturing a waveform received over the input port.
- a method for training a test and measurement instrument to suggest measurements.
- the method includes receiving training data including waveforms and corresponding known classifications via an input port.
- a plurality of classifiers are trained, via the processor, on the training data by iteratively applying each classifier to each waveform of the training data to obtain corresponding predicted waveform classifications.
- Training further includes comparing the predicted waveform classifications with the known classifications, and correcting each classifier that outputs a predicted waveform classification that does not match the known classification for the corresponding waveform.
- FIG. 1 is a block diagram of an embodiment of a test system including an oscilloscope configured to accept a plurality of input signals from a device under test (DUT).
- DUT device under test
- FIG. 2 is a block diagram of an embodiment of an oscilloscope.
- FIG. 3 is a block diagram of an embodiment of a test and measurement system configured to employ machine learning to classify waveforms and suggest corresponding measurements and actions.
- FIG. 4 is a block diagram illustrating an embodiment of machine learning objects including classifier and model data objects.
- FIG. 5 is a block diagram illustrating an embodiment of a method of implementing a learning phase in a test and measurement system.
- FIG. 6 is a block diagram illustrating an embodiment of a method of implementing an evaluation phase in a test and measurement system.
- references in the specification to embodiment, aspect, example, etc. indicate that the described item may include a particular feature, structure, or characteristic. However, every disclosed aspect may or may not necessarily include that particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same aspect unless specifically noted. Further, when a particular feature, structure, or characteristic is described in connection with a particular aspect, such feature, structure, or characteristic can be employed in connection with another disclosed aspect whether or not such feature is explicitly described in conjunction with such other disclosed aspect.
- the disclosed aspects may be implemented, in some cases, in hardware, firmware, software, or any combination thereof.
- the disclosed aspects may also be implemented as instructions carried by or stored on one or more transitory or non-transitory machine-readable (e.g., computer-readable) storage medium, which may be read and executed by one or more processors.
- a machine-readable storage medium may be embodied as any storage device, mechanism, or other physical structure for storing or transmitting information in a form readable by a machine (e.g., a volatile or non-volatile memory, a media disc, or other media device).
- FIG. 1 is a block diagram of an embodiment of a test system 100 including an oscilloscope 110 configured to accept one or more input signals as measurement data 125 , for example to test the signals from a device under test (DUT) 121 .
- DUT 121 may be any signal source configured to communicate via electrical and/or optical signals.
- DUT 121 may include any form of transmitter or a signal transmission medium coupled via one or more signal probes.
- DUT 121 may transmit a wide variety of waveforms as input signals that can be measured by the oscilloscope 110 as measurement data 125 , which is discussed more fully below.
- the waveforms may be transmitted in the form of sine waves, square waves, pulse width modulation signals, rising edge signals, falling edge signals, ramp signals, direct current (DC) signals, noise signals, sin(x)/x signals where x is a variable value, Gaussian signals, Lorentz signals, exponential rise signals, exponential decay signals, Haversine signals, cardiac signals, etc.
- the DUT 121 may optionally connect to the oscilloscope 110 via a bus 123 .
- a bus 123 is any communication system that transfers signals or data between two points. Many types of buses 123 employ specific communication protocols.
- bus 123 may be configured as a parallel bus, a Serial Peripheral Interface (SPI) bus, an Inter-Integrated Circuit (I2C) bus, a Universal Serial Bus (USB), a Local Interconnect Network (LIN) bus, a Controller Area Network (CAN) bus, an audio bus, an Aeronautical Radio Inc. data transfer standard 429 (ARINC429) bus, a Radio Sector standard 232 (RS232) bus, an Ethernet bus, a FlexRay bus, etc.
- the DUT 121 may be employed to train the oscilloscope 110 to classify the waveforms/buses in some aspects. In other aspects, the DUT 121 may be a device to be tested by the oscilloscope.
- the oscilloscope 110 is a test and measurement instrument configured to receive the measurement data 125 , classify the measurement data 125 to determine which type of waveform is being received or which type of bus 123 is connected to the oscilloscope, suggest measurements or actions to be taken based on the classification, and ultimately display relevant data on display 111 including one or more graticules.
- the oscilloscope 110 includes ports 115 for receiving the measurement data 125 and forwarding the signals/data to local hardware for conditioning, sampling, classification, etc.
- the oscilloscope 110 also includes controls 113 for receiving user input, for example alternating current (AC) or DC coupling controls, trigger level controls, trigger-level hysteresis controls to alter trigger-level hysteresis thresholds and margins, user selections, user over-rides, etc.
- controls 113 for receiving user input, for example alternating current (AC) or DC coupling controls, trigger level controls, trigger-level hysteresis controls to alter trigger-level hysteresis thresholds and margins, user selections, user over-rides, etc.
- AC alternating current
- a user can train or employ the oscilloscope to classify waveforms or buses and accept or reject suggested measurements or actions presented on the display 111 as a result of such classifications.
- oscilloscope 100 is presented as an example for purposes of clarity of discussion, but should not be considered limiting as multiple types of oscilloscopes, test and measurements systems, and other test setups may be employed without departing from the present disclosure.
- FIG. 2 is a block diagram of an embodiment of an oscilloscope 200 , which may be employed in a test system such as test system 100 .
- oscilloscope 200 may be substantially similar to oscilloscope 100 and connected to a DUT or other training device in similar fashion.
- Oscilloscope 200 may be employed to implement test and measurement system 300 , store and interact with machine learning objects 400 , and/or implement methods 500 , 600 , and/or any other method disclosed herein as shown in FIGS. 1-6 , respectively.
- Oscilloscope 200 includes input ports 215 which may be substantially similar to port 115 and may include any electrical and/or optical ports, receivers, etc. configured to accept an input signal including measurement or training data.
- Input ports 215 may include channel inputs, phase reference inputs, clock inputs, and/or any other signal input.
- Signal input ports 215 are coupled to signal analysis circuits 214 , which may include conditioning circuits, amplifiers, samplers, analog to digital converters, phase reference circuits, clock circuits, and/or any components employable to obtain measurement or training data from the input signal received via the input ports 215 .
- Signal analysis circuits 214 receive input signals from the signal input ports 215 , condition the signals, perform signal sampling, and/or digitize the signals and forward the results to memory 217 or processor 212 for analysis.
- Signal analysis circuits 214 may be implemented as an application specific integrated circuit (ASIC), a digital signal processor (DSP), or other processing circuitry.
- ASIC application specific integrated circuit
- DSP digital signal processor
- Signal analysis circuits 214 are coupled to processor 212 , which may be implemented as a general purpose processor.
- Processor 212 is configured to execute instructions from memory 217 and perform any methods and/or associated steps indicated by the instructions.
- Memory 217 may be implemented as processor cache, random access memory (RAM), read only memory (ROM), solid state memory, hard disk drive(s), or any other memory type.
- Memory 217 acts as a non-transitory medium for storing computer program products and other instructions, storing waveform samples, and/or storing other data objects such as classifiers and models as discussed below. Memory 217 provides such stored information to the processor 212 for computation as needed.
- Processor 212 may include a machine learning module 216 .
- the machine learning module 216 is a processing circuit and/or set of executing instructions configured to operate machine learning algorithms, such as machine learning module 333 .
- the processor 212 and machine learning module 216 may be employed during a learning phase to train data objects such as classifiers 335 and 435 , and models 336 and 436 .
- Such training may employ training data such as training data 331 .
- the machine learning module 216 is also configured to operate machine learning algorithms and a recommender, such as recommender 338 , during an evaluation and/or action phase.
- machine learning module 216 is configured to perform methods 500 , 600 , and/or any other methods discussed herein.
- the machine learning module 216 may also be implemented, in part, in the memory 217 and/or other components in oscilloscope 200 .
- User controls 213 are coupled at least to the processor 212 and signal analysis circuits 214 .
- User controls 213 may include strobe inputs, gain controls, triggers, display adjustments, power controls, or any other controls employable by a user to display an input signal on display 211 .
- User controls 213 may also allow the user to select particular measurements or actions to be taken when analyzing a signal.
- the machine learning module 216 may suggest measurements and/or actions via the display 211 , and the user controls 213 may be configured to allow the user to accept or override the suggested actions or measurements.
- the user controls 213 are integrated, in whole or in part, in the display 211 .
- Display 211 may be a digital screen or a cathode ray tube based display.
- Display 211 includes a plurality of graticules for displaying corresponding input signals, for example as eye diagrams, histograms, heat maps, time domain signals, frequency domain signals, etc.
- oscilloscope 200 may be configured to employ the machine learning module 216 to train classifiers and modules to classify training data to determine classifications for incoming waveforms and/or buses as discussed below.
- the oscilloscope 200 may also be configured to employ the classifiers and modules to classify measurement data and suggest measurements and/or actions as discussed below. Further, the oscilloscope 200 may take action, as directed by the suggested measurements and/or suggested actions, without requiring direct user initiation or approval.
- FIG. 3 is a block diagram of an embodiment of a test and measurement system 300 configured to employ machine learning to classify waveforms and suggest corresponding measurements and actions.
- Test and measurement system 300 may be implemented in an oscilloscope, such as oscilloscope 100 and/or 200 , configured to receive signals from a DUT, such as DUT 121 or other training hardware.
- Test and measurement system 300 includes a machine learning module 333 , classifiers 335 , recommender 338 , and models 336 , which can be implemented by a general purpose processor, application specific processor, memory, or combinations thereof (e.g. processor 212 , machine learning module 216 , and memory 217 ).
- the test and measurement system 300 accepts training data 331 and captured waveform measurements/device states 337 as inputs and generates output 339 as described below.
- Machine learning module 333 (e.g. machine learning algorithm) is a set of instructions configured to perform a task, measure the performance of the task, and alter the performance of the task based on the measurements to improve performance based on experience.
- Machine learning module 333 may be implemented according to a supervised learning algorithm including analytical learning, artificial neural network, backpropagation, boosting, Bayesian statistics, case-based reasoning, decision tree learning, inductive logic programming, Gaussian process regression, group method of data handling, kernel estimators, learning automata, minimum message length (decision trees, decision graphs, etc.), multilinear subspace learning, naive Bayes classifier, maximum entropy classifier, conditional random field, nearest neighbor algorithm, Probably Approximately Correct (PAC) learning, ripple down rules, symbolic machine learning, sub-symbolic machine learning, support vector machines, Minimum Complexity Machines (MCM), random forests, ensembles of classifiers, ordinal classification, data pre-processing, handling imbalanced datasets, statistical relational learning, and/or Proaft
- machine learning module 333 receives training data 331 .
- Training data 331 is a set of waveforms and corresponding known classifications.
- Machine learning module 333 creates and trains a plurality of classifiers 335 to classify the training data 331 .
- a classifier 335 is any component configured to provide a classification of incoming data based on preconfigured rules, and modify such rules through training.
- a classifier 335 may include a random decision forest with multiple decision trees.
- Each classifier 335 corresponds to a particular classification, such as sine wave, square wave, pulse width modulation, rising edge, falling edge, ramp, DC, noise, sin(x)/x, Gaussian, Lorentz, exponential rise, exponential decay, Haversine, cardiac, parallel bus, SPI bus, I2C bus, USB, LIN bus, CAN bus, audio bus, ARINC429 bus, RS232 bus, Ethernet bus, FlexRay bus, etc.
- Machine learning module 333 applies each set of waveforms in the training data 331 to each classifier 335 , and each classifier 335 returns a result.
- a sine wave classifier 335 should return a match and all other classifiers should not return a match.
- the machine learning module 333 then employs the known classification to correct the rules of any classifier returning an incorrect result. For example, when a USB classifier 335 returns a match when a Gaussian waveform is applied (e.g. an incorrect match), the machine learning module 333 corrects the rules of the USB classifier 335 .
- Classifiers 335 may employ various signal qualities to classify training data 331 and measurement data (e.g. captured waveform measurements/device states 337 ).
- classifiers 335 may employ signal amplitude characteristics such as amplitude, maximum amplitude, minimum amplitude, peak-to-peak, positive overshoot, negative overshoot, mean amplitude, signal Root Mean Square (RMS), AC RMS, DC common mode, AC common mode (e.g. peak-to-peak), signal area, differential Crossover, signal top, signal base, bit high, bit low, bit amplitude, transmission/network transmission (T/nT) ratio, etc.
- signal amplitude characteristics such as amplitude, maximum amplitude, minimum amplitude, peak-to-peak, positive overshoot, negative overshoot, mean amplitude, signal Root Mean Square (RMS), AC RMS, DC common mode, AC common mode (e.g. peak-to-peak), signal area, differential Crossover, signal top, signal base, bit high, bit low,
- Classifiers 335 may also employ time related characteristics such as period, frequency, data rate, positive pulse width, negative pulse width, skew, rise time, fall time, delay, rising slew rate, falling slew rate, phase, positive duty cycle, negative duty cycle, burst width, setup time, hold time, time outside level, high time, low time, duration of N-periods where N is a variable number of periods, Spread Spectrum Clocking (SSC) frequency deviation, SSC modulation rate, positive edge count, negative edge count, pulse count, burst, etc.
- SSC Spread Spectrum Clocking
- Classifiers 335 may also employ jitter related characteristics such as Time Interval Error (TIE), phase noise, random jitter (RJ), RJ anti-aliasing (RJ-aa), non-periodic jitter (NPJ), total jitter at specified bit error rate (TJ@BER), deterministic jitter (DJ), DJ anti-aliasing (DJ-aa), periodic jitter (PJ), data-dependent jitter (DDJ), duty cycle distortion (DCD), interval that includes all but 10 ⁇ 2 jitter distribution (J2), interval that includes all but 10 ⁇ 9 jitter distribution (J9), sub-rate jitter (SRJ), frequency (F)/2, F/4, F/8, etc.
- TIE Time Interval Error
- RJ random jitter
- RJ-aa RJ anti-aliasing
- NPJ non-periodic jitter
- TJ@BER total jitter at specified bit error rate
- DJ deterministic jitter
- Classifiers 335 may also employ power related characteristics such as power quality power derivative, modulation, power harmonics, switching loss, ripple, etc. Accordingly, the classifiers 335 are configured to determine a classification for the training data and measurement data by examining signal amplitude, time characteristics, jitter, and/or power.
- the training data 331 may be delivered to the classifiers 335 in various forms, including raw point data, waveform images, vertical histograms, device settings or information (e.g. device state), a collection of multiple acquisitions combined into a heat map, waveform measurements, etc.
- classifiers 335 may employ a plurality of machine learning algorithms, with specified machine learning algorithms selected to classify particular waveform types. In other words, some machine learning algorithms may be better suited to classify a first set waveforms, which other machine learning algorithms may be better suited to classify a second set of waveforms. Thus some classifiers 335 may employ different machine learning algorithms than other classifiers 335 in the same system.
- a model 336 is built (e.g. by the machine learning module 333 ) during the learning phase to correspond with each classifier 335 (and hence each classification).
- Some models 336 are built to correspond with waveforms incoming over an input port (e.g. ports 115 / 215 ), while others correspond with a bus (e.g. bus 123 ) connected to the input port.
- a bus e.g. bus 123
- measurements that are highly determinative for some classifications may not be useful for other classifications.
- feature selection is employed by the machine learning module 333 to remove unneeded measurements from each classifier 335 and generate a corresponding model 336 with only relevant data.
- each model 336 describes the measurements the corresponding classifier 335 can accept as input.
- each model 336 can be configured to include particular measurements or actions user may want to take in the event that incoming data indicates a corresponding classification.
- the machine learning module 333 Upon completely processing the training data 331 , the machine learning module 333 has created and trained the classifiers 335 and models 336 .
- the state of the machine learning module 333 has created and trained the classifiers 335 and models 336 may be stored in memory for run time use by an oscilloscope.
- a master test and measurement instrument may train the machine learning module 333 , classifiers 335 , and models 336 and store the results in a memory readable format to be loaded on multiple oscilloscopes, when such oscilloscopes are manufactured.
- each oscilloscope can be trained during the manufacture process.
- An end user employs the test and measurement system 300 at run time as part of an evaluation phase.
- captured waveform measurements/device states 337 are received by the machine learning module 333 , for example via an input port/signal analysis circuit in the case of a waveform or via the signal analysis circuits and/or memory in the case of a device state.
- Each classifier 335 is applied to the measurements/states 337 .
- the classifiers 335 each indicate a match or lack of match. In some aspects, the classifiers 335 also return a confidence value.
- the measurements/states 337 received during the evaluation phase may contain virtually any type of data, and the classifications are unknown. Accordingly, a classification is determined if only one classifier 335 returns a match.
- the system 300 is unable to classify the incoming signal.
- the classification e.g. waveform or bus type
- the recommender 339 is forwarded to the recommender 339 .
- the recommender 339 is a component configured to recommend particular actions or measurements to a user.
- the recommender 338 receives the classification and obtains the corresponding model 336 . Based on the model 336 returned, the recommender 338 can recommend particular measurements that a user may find useful for the classifications, such as useful trigger points, particular transforms, etc. that are relevant to the classified waveform or bus. Further, the recommender 338 can recommend particular actions that a user may wish to take based on the classification, such as selecting configuring a bus, changing display ranges, etc. In addition, the recommender 338 may also reorder lists of suggested actions/measurements so the most relevant actions/measurements for the particular classification are listed first.
- the recommender 338 may grey out or remove actions/measurements that are unsuited for a particular classification.
- the recommender 338 then sends such suggestions to the user via an output 339 , which may include a display such as display 111 / 211 .
- the user may the employ the controls (e.g. controls 113 / 213 ) to accept or reject the suggestions.
- the recommender 338 may also take any suggested action or initiate any suggested measurements immediately without requiring direct user initiation, approval, or interaction.
- FIG. 4 is a block diagram illustrating an embodiment of machine learning objects 400 including classifier 435 and model data 436 objects.
- Classifier 435 and model 436 are substantially similar to classifiers 335 and models 336 , respectively.
- Classifier 435 is an example of a classifier 335 configured to implement a random forest machine learning algorithm.
- Classifier 435 includes a decision forest 441 , which further includes a plurality of decision trees 443 . Specifically, a decision forest 441 is created for each classification (e.g. as discussed with respect to classifier 335 ). During training, decision trees 443 are grown in the decision forest 441 based on the training data.
- Various signal qualities are employed by the decision trees 443 to classify the training data, as discussed above, and the decision trees 443 are corrected when an incorrect result is returned (e.g. improper match or improper lack of match).
- one hundred decision trees 443 are employed in a decision forest 441 . Randomization is employed to reduce the occurrence of overfitting of the decision trees 443 to the training data set.
- a confidence threshold 445 may be stored to each classifier 435 .
- a confidence threshold 445 indicates a minimum percentage of decision trees 443 in the decision forest 441 that should output a positive classification (e.g. return a match) to result in a positive classification for the corresponding decision forest 441 and corresponding classifier 435 .
- a confidence threshold 445 of eighty percent may be used to indicate that eighty percent of the decision trees 443 should indicate a match before the system is confident that a match has actually been found.
- cross-validation may be employed to evaluate the accuracy of the decision forest 441 with respect to the training data set. The cross-validation results may be employed to further correct the output of the decision forest relative to the training data.
- measurement data is received via an input port and forwarded to the processor.
- the processor applies each of the classifiers 435 to the measurement data to determine a classification for the measurement data.
- the decision forest 443 applies each decision tree 443 and receives an output.
- the classifier 435 employs the percentage of decision tree 443 outputs that report a match as a confidence value 447 .
- the confidence value 447 output by the decision forest 441 exceeds a confidence threshold 445 of the classifier 435 , the decision tree 441 and hence the classifier 435 is considered to have returned a match.
- each classifier 435 corresponds with a model 436 that indicates suggested measurements 444 and suggested actions 446 associated with the classification of the classifier 435 .
- the recommender selects the model 436 corresponding to the classification to obtain the corresponding suggested measurements 444 and/or suggested actions 446 .
- the recommender can then configure the test and measurement instrument to employ the suggested measurements 444 and/or suggested actions 446 corresponding to the selected model 436 when capturing a waveform received over the input port.
- suggested measurements 444 and/or suggested actions 446 are set during the learning phase to suggest intuitive actions for the user.
- Suggested measurements 444 may include sorting, enabling, highlighting, and/or hiding any of the measurements listed with respect to classifier 335 on the display.
- Suggested actions 446 may include sorting, enabling, highlighting, and/or hiding any of the bus categories listed with respect to classifier 335 on the display.
- FIG. 5 is a block diagram illustrating an embodiment of a method 500 of implementing a learning phase in a test and measurement system.
- Method 500 may be employed by an oscilloscope, such as oscilloscope 100 / 200 operating a test and measurement system, such as system 300 with data structures such as machine learning objects 400 .
- training data such as training data 331
- the training data represents waveforms and/or buses and may also include corresponding known classifications.
- a processor employs a machine learning algorithm to train the classifiers on the training data based on the known classifications. Specifically, each classifier is iteratively applied to each waveform of the training data to obtain corresponding predicted waveform classifications.
- the predicted waveform classifications are compared with the known classifications. Further, each classifier that outputs a predicted waveform classification that does not match the known classification for the corresponding waveform is corrected. By iteratively testing and correcting each classifier, the classifiers progressively become more accurate when attempting classification of new input data.
- confidence thresholds may optionally be stored for the classifiers. For example, decision forest based classifiers may employ confidence thresholds, while other learning algorithms may not employ confidence thresholds and may instead return only a match (e.g. a classification) or a lack of a match (no classification) for each classifier.
- Models such as models 436 , are generated at block 507 . Sets of suggested measurements and/or suggested actions are added to each model.
- the suggested measurements/actions include instructions executed by the test and measurement system upon matching measurement data with a classification of a classifier corresponding to the model. For example, suggested measurements associated with waveform classification are stored to a classifier corresponding to waveform classification, and suggested actions associated with bus classification are stored to a classifier corresponding to bus classification.
- cross validation of the training data is employed to evaluate the accuracy of and/or further correct the classifiers. Cross validation may be performed on both waveform based training data and bus based training data.
- FIG. 6 is a block diagram illustrating an embodiment of a method 600 of implementing an evaluation phase in a test and measurement system.
- Method 600 may be employed by an oscilloscope, such as oscilloscope 100 / 200 operating a test and measurement system, such as system 300 with data structures such as machine learning objects 400 .
- method 600 may be employed after the training of method 500 is completed.
- measurement data is received, for example via an input port.
- the received measurement data corresponds to a measured waveform or bus input, and is received for purposes of classification.
- each of the classifiers are applied to the measurement data to determine a classification, for example for a measured waveform or bus input.
- the classifiers each return a classification by examining signal amplitude, time characteristics, jitter, power, etc. as described above.
- a confidence value is produced for some or all of the classifiers to support determination of a classification.
- the confidence values of the classifiers are compared to their respective confidence thresholds to determine whether a single classifier produces a confidence value in excess of a corresponding stored confidence threshold. If two classifiers return a match, then classification is unclear. If no classifier returns a match, then classification is not possible. In either case, the method 600 proceed to block 609 . In such a case, classification is unsuccessful. The result may be displayed on the test and measurement system display and no action is taken.
- a model corresponding to the classifier returning the determined classification is selected, for example by the recommender.
- the model corresponds to suggested measurements and/or actions for the classifier.
- the recommender implements the suggested measurements and/or actions by configuring the test and measurement instrument to employ the suggested measurements/actions corresponding to the selected model when capturing the measured waveform, for example upon approval by the user via controls.
- the recommender can either display the suggested actions/measurements to the user on the display by emphasizing or deemphasizing the suggestions, removing actions/measurements from the display that are irrelevant to the determine classification, or by preparing the test and measurement system to perform the actions upon receiving approval from the user.
- Feature selection may also be employed on each classifier's classification by reducing a corresponding set of classifier inputs in the models by removing inputs that are not useful for the corresponding classification.
- the oscilloscope 100 / 200 operating test and measurement system 300 with data objects 400 according to methods 500 - 600 improve the functionality of an oscilloscope by allowing the oscilloscope to classify inputs to the oscilloscope and alter the oscilloscope display accordingly to emphasize or de-emphasize device functions that are relevant to the user.
- the devices, systems, and methods disclosed herein allow the user to access relevant functions much more easily and clearly the other systems.
- Embodiments of the invention may operate on a particularly created hardware, on firmware, digital signal processors, or on a specially programmed general purpose computer including a processor operating according to programmed instructions.
- controller or “processor” as used herein are intended to include microprocessors, microcomputers, ASICs, and dedicated hardware controllers.
- One or more aspects of the invention may be embodied in computer-usable data and computer-executable instructions, such as in one or more program modules, executed by one or more computers (including monitoring modules), or other devices.
- program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types when executed by a processor in a computer or other device.
- the computer executable instructions may be stored on a non-transitory computer readable medium such as a hard disk, optical disk, removable storage media, solid state memory, RAM, etc.
- a non-transitory computer readable medium such as a hard disk, optical disk, removable storage media, solid state memory, RAM, etc.
- the functionality of the program modules may be combined or distributed as desired in various embodiments.
- the functionality may be embodied in whole or in part in firmware or hardware equivalents such as integrated circuits, field programmable gate arrays (FPGA), and the like.
- Particular data structures may be used to more effectively implement one or more aspects of the invention, and such data structures are contemplated within the scope of computer executable instructions and computer-usable data described herein.
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Data Mining & Analysis (AREA)
- General Engineering & Computer Science (AREA)
- Artificial Intelligence (AREA)
- Evolutionary Computation (AREA)
- Mathematical Physics (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Computing Systems (AREA)
- Medical Informatics (AREA)
- Bioinformatics & Computational Biology (AREA)
- Evolutionary Biology (AREA)
- Life Sciences & Earth Sciences (AREA)
- Bioinformatics & Cheminformatics (AREA)
- Algebra (AREA)
- Pure & Applied Mathematics (AREA)
- Mathematical Optimization (AREA)
- Mathematical Analysis (AREA)
- Computational Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Tests Of Electronic Circuits (AREA)
- Measurement Of Mechanical Vibrations Or Ultrasonic Waves (AREA)
Abstract
Description
- This disclosure is directed to a system and methods for oscilloscope operation, and, more particularly, to a system and methods for detecting input waveform types and suggesting corresponding measurement settings for the oscilloscope.
- Test and measurement systems are designed to receive signal inputs, sample the signals, and display the result as a waveform. Various settings can be employed to control the manner of sampling, the nature of the samples taken, and the manner in which the waveform is displayed. Some advanced test and measurement systems include large numbers of potential control settings, and many such settings are only useful for specific input types. Accordingly, advanced models can inundate the user with choices, while making relevant settings exceedingly difficult to find.
- Various approaches have been employed to combat the usability problems inherent with a complex control interface. For example, commonly-used measurements can be placed at the top of the display for easier access. However, this approach is not context sensitive, and a commonly used measurement for some users may not be commonly-used for other users. Another approach involves automatically adding potential measurements to the display screen, but such approaches are not tailored to the received waveform and may contain overly general or irrelevant information. Yet another approach allows a user to select a snapshot window of a measured waveform and all measurements related to the window are displayed including both relevant and irrelevant data. Such an approach still requires a user to sift through irrelevant information to find useful measurement options for an incoming waveform.
- Embodiments of the invention address these and other issues.
- Embodiments of the disclosed subject matter include an oscilloscope configured to employ machine learning to classify incoming waveforms and/or attached buses and suggest measurements or other actions based on the classification. The oscilloscope undergoes a learning phase, where a plurality of classifiers receive training data representing particular waveforms or buses along with known classifications. The classifiers are applied to the training data and corrected when classifications output by the classifiers are incorrect in light of the known classifications. Confidence thresholds can also be stored for each classifier. Corresponding models are generated for each classifier, and suggested measurements and/or actions are added to each model. Further, feature selection may be employed on each classifier to reduce a set of classifier inputs by removing inputs that are not useful for the corresponding classification. Cross validation may also be employed to increase the accuracy of the classifiers. Such machine learning may occur for each manufactured oscilloscope or may occur for a master oscilloscope, with the results loaded into a plurality of oscilloscope at the point of manufacture. At runtime, the oscilloscope receives incoming waveforms and applies each classifier to the incoming waveform. Each classifier returns a confidence value for a corresponding classification. If a single classifier returns a confidence value in excess of the classifier's confidence threshold, then the waveform has been properly classified. The classification is forwarded to a recommender, which obtains the model associated with the classification and implements any suggested measurements or actions.
- Accordingly, in at least some aspects a test and measurement instrument includes an input port configured to receive measurement data, and a processor coupled to the input port. The processor is configured to apply a plurality of classifiers to the measurement data to determine a classification for the measurement data. The processor also selects a model corresponding to the classification, where the model corresponds to suggested measurements. Further, the processor configures the test and measurement instrument to employ the suggested measurements corresponding to the selected model when capturing a waveform received over the input port.
- In another aspect, a method is disclosed for training a test and measurement instrument to suggest measurements. The method includes receiving training data including waveforms and corresponding known classifications via an input port. A plurality of classifiers are trained, via the processor, on the training data by iteratively applying each classifier to each waveform of the training data to obtain corresponding predicted waveform classifications. Training further includes comparing the predicted waveform classifications with the known classifications, and correcting each classifier that outputs a predicted waveform classification that does not match the known classification for the corresponding waveform.
- These and other aspects are discussed in more detail herein below.
-
FIG. 1 is a block diagram of an embodiment of a test system including an oscilloscope configured to accept a plurality of input signals from a device under test (DUT). -
FIG. 2 is a block diagram of an embodiment of an oscilloscope. -
FIG. 3 is a block diagram of an embodiment of a test and measurement system configured to employ machine learning to classify waveforms and suggest corresponding measurements and actions. -
FIG. 4 is a block diagram illustrating an embodiment of machine learning objects including classifier and model data objects. -
FIG. 5 is a block diagram illustrating an embodiment of a method of implementing a learning phase in a test and measurement system. -
FIG. 6 is a block diagram illustrating an embodiment of a method of implementing an evaluation phase in a test and measurement system. - The aspects of the present disclosure are susceptible to various modifications and alternative forms. Specific aspects have been shown by way of example in the drawings and are described in detail herein below. However, it should be noted that the examples disclosed herein are presented for the purposes of clarity of discussion and are not intended to limit the scope of the general concepts disclosed to the specific embodiments described herein unless expressly limited. As such, the present disclosure is intended to cover all modifications, equivalents, and alternatives of the described aspects in light of the attached drawings and claims.
- References in the specification to embodiment, aspect, example, etc., indicate that the described item may include a particular feature, structure, or characteristic. However, every disclosed aspect may or may not necessarily include that particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same aspect unless specifically noted. Further, when a particular feature, structure, or characteristic is described in connection with a particular aspect, such feature, structure, or characteristic can be employed in connection with another disclosed aspect whether or not such feature is explicitly described in conjunction with such other disclosed aspect.
- The disclosed aspects may be implemented, in some cases, in hardware, firmware, software, or any combination thereof. The disclosed aspects may also be implemented as instructions carried by or stored on one or more transitory or non-transitory machine-readable (e.g., computer-readable) storage medium, which may be read and executed by one or more processors. A machine-readable storage medium may be embodied as any storage device, mechanism, or other physical structure for storing or transmitting information in a form readable by a machine (e.g., a volatile or non-volatile memory, a media disc, or other media device).
-
FIG. 1 is a block diagram of an embodiment of atest system 100 including anoscilloscope 110 configured to accept one or more input signals asmeasurement data 125, for example to test the signals from a device under test (DUT) 121.DUT 121 may be any signal source configured to communicate via electrical and/or optical signals. For example,DUT 121 may include any form of transmitter or a signal transmission medium coupled via one or more signal probes.DUT 121 may transmit a wide variety of waveforms as input signals that can be measured by theoscilloscope 110 asmeasurement data 125, which is discussed more fully below. For example, the waveforms may be transmitted in the form of sine waves, square waves, pulse width modulation signals, rising edge signals, falling edge signals, ramp signals, direct current (DC) signals, noise signals, sin(x)/x signals where x is a variable value, Gaussian signals, Lorentz signals, exponential rise signals, exponential decay signals, Haversine signals, cardiac signals, etc. The DUT 121 may optionally connect to theoscilloscope 110 via abus 123. Abus 123 is any communication system that transfers signals or data between two points. Many types ofbuses 123 employ specific communication protocols. For example,bus 123 may be configured as a parallel bus, a Serial Peripheral Interface (SPI) bus, an Inter-Integrated Circuit (I2C) bus, a Universal Serial Bus (USB), a Local Interconnect Network (LIN) bus, a Controller Area Network (CAN) bus, an audio bus, an Aeronautical Radio Inc. data transfer standard 429 (ARINC429) bus, a Radio Sector standard 232 (RS232) bus, an Ethernet bus, a FlexRay bus, etc. TheDUT 121 may be employed to train theoscilloscope 110 to classify the waveforms/buses in some aspects. In other aspects, theDUT 121 may be a device to be tested by the oscilloscope. - The
oscilloscope 110 is a test and measurement instrument configured to receive themeasurement data 125, classify themeasurement data 125 to determine which type of waveform is being received or which type ofbus 123 is connected to the oscilloscope, suggest measurements or actions to be taken based on the classification, and ultimately display relevant data ondisplay 111 including one or more graticules. Theoscilloscope 110 includesports 115 for receiving themeasurement data 125 and forwarding the signals/data to local hardware for conditioning, sampling, classification, etc. Theoscilloscope 110 also includescontrols 113 for receiving user input, for example alternating current (AC) or DC coupling controls, trigger level controls, trigger-level hysteresis controls to alter trigger-level hysteresis thresholds and margins, user selections, user over-rides, etc. By employing the controls 103, a user can train or employ the oscilloscope to classify waveforms or buses and accept or reject suggested measurements or actions presented on thedisplay 111 as a result of such classifications. It should be noted thatoscilloscope 100 is presented as an example for purposes of clarity of discussion, but should not be considered limiting as multiple types of oscilloscopes, test and measurements systems, and other test setups may be employed without departing from the present disclosure. -
FIG. 2 is a block diagram of an embodiment of anoscilloscope 200, which may be employed in a test system such astest system 100. For example,oscilloscope 200 may be substantially similar tooscilloscope 100 and connected to a DUT or other training device in similar fashion.Oscilloscope 200 may be employed to implement test andmeasurement system 300, store and interact with machine learning objects 400, and/or implementmethods FIGS. 1-6 , respectively.Oscilloscope 200 includesinput ports 215 which may be substantially similar toport 115 and may include any electrical and/or optical ports, receivers, etc. configured to accept an input signal including measurement or training data.Input ports 215 may include channel inputs, phase reference inputs, clock inputs, and/or any other signal input.Signal input ports 215 are coupled to signalanalysis circuits 214, which may include conditioning circuits, amplifiers, samplers, analog to digital converters, phase reference circuits, clock circuits, and/or any components employable to obtain measurement or training data from the input signal received via theinput ports 215.Signal analysis circuits 214 receive input signals from thesignal input ports 215, condition the signals, perform signal sampling, and/or digitize the signals and forward the results tomemory 217 orprocessor 212 for analysis.Signal analysis circuits 214 may be implemented as an application specific integrated circuit (ASIC), a digital signal processor (DSP), or other processing circuitry.Signal analysis circuits 214 are coupled toprocessor 212, which may be implemented as a general purpose processor.Processor 212 is configured to execute instructions frommemory 217 and perform any methods and/or associated steps indicated by the instructions.Memory 217 may be implemented as processor cache, random access memory (RAM), read only memory (ROM), solid state memory, hard disk drive(s), or any other memory type.Memory 217 acts as a non-transitory medium for storing computer program products and other instructions, storing waveform samples, and/or storing other data objects such as classifiers and models as discussed below.Memory 217 provides such stored information to theprocessor 212 for computation as needed. -
Processor 212 may include amachine learning module 216. Themachine learning module 216 is a processing circuit and/or set of executing instructions configured to operate machine learning algorithms, such asmachine learning module 333. For example, theprocessor 212 andmachine learning module 216 may be employed during a learning phase to train data objects such asclassifiers models training data 331. Themachine learning module 216 is also configured to operate machine learning algorithms and a recommender, such asrecommender 338, during an evaluation and/or action phase. As such,machine learning module 216 is configured to performmethods machine learning module 216 may also be implemented, in part, in thememory 217 and/or other components inoscilloscope 200. - User controls 213 are coupled at least to the
processor 212 andsignal analysis circuits 214. User controls 213 may include strobe inputs, gain controls, triggers, display adjustments, power controls, or any other controls employable by a user to display an input signal ondisplay 211. User controls 213 may also allow the user to select particular measurements or actions to be taken when analyzing a signal. Accordingly, themachine learning module 216 may suggest measurements and/or actions via thedisplay 211, and the user controls 213 may be configured to allow the user to accept or override the suggested actions or measurements. In some aspects, the user controls 213 are integrated, in whole or in part, in thedisplay 211.Display 211 may be a digital screen or a cathode ray tube based display.Display 211 includes a plurality of graticules for displaying corresponding input signals, for example as eye diagrams, histograms, heat maps, time domain signals, frequency domain signals, etc. Accordingly,oscilloscope 200 may be configured to employ themachine learning module 216 to train classifiers and modules to classify training data to determine classifications for incoming waveforms and/or buses as discussed below. Theoscilloscope 200 may also be configured to employ the classifiers and modules to classify measurement data and suggest measurements and/or actions as discussed below. Further, theoscilloscope 200 may take action, as directed by the suggested measurements and/or suggested actions, without requiring direct user initiation or approval. -
FIG. 3 is a block diagram of an embodiment of a test andmeasurement system 300 configured to employ machine learning to classify waveforms and suggest corresponding measurements and actions. Test andmeasurement system 300 may be implemented in an oscilloscope, such asoscilloscope 100 and/or 200, configured to receive signals from a DUT, such asDUT 121 or other training hardware. Test andmeasurement system 300 includes amachine learning module 333,classifiers 335,recommender 338, andmodels 336, which can be implemented by a general purpose processor, application specific processor, memory, or combinations thereof (e.g. processor 212,machine learning module 216, and memory 217). The test andmeasurement system 300 acceptstraining data 331 and captured waveform measurements/device states 337 as inputs and generatesoutput 339 as described below. - Machine learning module 333 (e.g. machine learning algorithm) is a set of instructions configured to perform a task, measure the performance of the task, and alter the performance of the task based on the measurements to improve performance based on experience.
Machine learning module 333 may be implemented according to a supervised learning algorithm including analytical learning, artificial neural network, backpropagation, boosting, Bayesian statistics, case-based reasoning, decision tree learning, inductive logic programming, Gaussian process regression, group method of data handling, kernel estimators, learning automata, minimum message length (decision trees, decision graphs, etc.), multilinear subspace learning, naive Bayes classifier, maximum entropy classifier, conditional random field, nearest neighbor algorithm, Probably Approximately Correct (PAC) learning, ripple down rules, symbolic machine learning, sub-symbolic machine learning, support vector machines, Minimum Complexity Machines (MCM), random forests, ensembles of classifiers, ordinal classification, data pre-processing, handling imbalanced datasets, statistical relational learning, and/or Proaftn. For purposes of clarity,machine learning module 333 is discussed in terms of random forests, referred to herein as decision forests, but multiple combinations of supervised learning algorithms may be employed. Further, deep learning algorithms may also be employed as part ofmachine learning module 333. - During a learning phase,
machine learning module 333 receivestraining data 331.Training data 331 is a set of waveforms and corresponding known classifications.Machine learning module 333 creates and trains a plurality ofclassifiers 335 to classify thetraining data 331. Aclassifier 335 is any component configured to provide a classification of incoming data based on preconfigured rules, and modify such rules through training. For example, aclassifier 335 may include a random decision forest with multiple decision trees. Eachclassifier 335 corresponds to a particular classification, such as sine wave, square wave, pulse width modulation, rising edge, falling edge, ramp, DC, noise, sin(x)/x, Gaussian, Lorentz, exponential rise, exponential decay, Haversine, cardiac, parallel bus, SPI bus, I2C bus, USB, LIN bus, CAN bus, audio bus, ARINC429 bus, RS232 bus, Ethernet bus, FlexRay bus, etc.Machine learning module 333 applies each set of waveforms in thetraining data 331 to eachclassifier 335, and eachclassifier 335 returns a result. For example, when trainingdata 331 consistent with a sine wave is forwarded to eachclassifier 335, asine wave classifier 335 should return a match and all other classifiers should not return a match. Themachine learning module 333 then employs the known classification to correct the rules of any classifier returning an incorrect result. For example, when aUSB classifier 335 returns a match when a Gaussian waveform is applied (e.g. an incorrect match), themachine learning module 333 corrects the rules of theUSB classifier 335. -
Classifiers 335 may employ various signal qualities to classifytraining data 331 and measurement data (e.g. captured waveform measurements/device states 337). For example,classifiers 335 may employ signal amplitude characteristics such as amplitude, maximum amplitude, minimum amplitude, peak-to-peak, positive overshoot, negative overshoot, mean amplitude, signal Root Mean Square (RMS), AC RMS, DC common mode, AC common mode (e.g. peak-to-peak), signal area, differential Crossover, signal top, signal base, bit high, bit low, bit amplitude, transmission/network transmission (T/nT) ratio, etc.Classifiers 335 may also employ time related characteristics such as period, frequency, data rate, positive pulse width, negative pulse width, skew, rise time, fall time, delay, rising slew rate, falling slew rate, phase, positive duty cycle, negative duty cycle, burst width, setup time, hold time, time outside level, high time, low time, duration of N-periods where N is a variable number of periods, Spread Spectrum Clocking (SSC) frequency deviation, SSC modulation rate, positive edge count, negative edge count, pulse count, burst, etc.Classifiers 335 may also employ jitter related characteristics such as Time Interval Error (TIE), phase noise, random jitter (RJ), RJ anti-aliasing (RJ-aa), non-periodic jitter (NPJ), total jitter at specified bit error rate (TJ@BER), deterministic jitter (DJ), DJ anti-aliasing (DJ-aa), periodic jitter (PJ), data-dependent jitter (DDJ), duty cycle distortion (DCD), interval that includes all but 10−2 jitter distribution (J2), interval that includes all but 10−9 jitter distribution (J9), sub-rate jitter (SRJ), frequency (F)/2, F/4, F/8, etc.Classifiers 335 may also employ power related characteristics such as power quality power derivative, modulation, power harmonics, switching loss, ripple, etc. Accordingly, theclassifiers 335 are configured to determine a classification for the training data and measurement data by examining signal amplitude, time characteristics, jitter, and/or power. Thetraining data 331 may be delivered to theclassifiers 335 in various forms, including raw point data, waveform images, vertical histograms, device settings or information (e.g. device state), a collection of multiple acquisitions combined into a heat map, waveform measurements, etc. As a wide variety of training data and classifications types may be employed byclassifiers 335, a plurality ofclassifiers 335 may employ a plurality of machine learning algorithms, with specified machine learning algorithms selected to classify particular waveform types. In other words, some machine learning algorithms may be better suited to classify a first set waveforms, which other machine learning algorithms may be better suited to classify a second set of waveforms. Thus someclassifiers 335 may employ different machine learning algorithms thanother classifiers 335 in the same system. - A
model 336 is built (e.g. by the machine learning module 333) during the learning phase to correspond with each classifier 335 (and hence each classification). Somemodels 336 are built to correspond with waveforms incoming over an input port (e.g.ports 115/215), while others correspond with a bus (e.g. bus 123) connected to the input port. Hence, measurements that are highly determinative for some classifications may not be useful for other classifications. Accordingly, feature selection is employed by themachine learning module 333 to remove unneeded measurements from eachclassifier 335 and generate acorresponding model 336 with only relevant data. Accordingly, eachmodel 336 describes the measurements thecorresponding classifier 335 can accept as input. Further, eachmodel 336 can be configured to include particular measurements or actions user may want to take in the event that incoming data indicates a corresponding classification. - Upon completely processing the
training data 331, themachine learning module 333 has created and trained theclassifiers 335 andmodels 336. The state of themachine learning module 333 has created and trained theclassifiers 335 andmodels 336 may be stored in memory for run time use by an oscilloscope. For example, a master test and measurement instrument may train themachine learning module 333,classifiers 335, andmodels 336 and store the results in a memory readable format to be loaded on multiple oscilloscopes, when such oscilloscopes are manufactured. In another aspect, each oscilloscope can be trained during the manufacture process. - An end user employs the test and
measurement system 300 at run time as part of an evaluation phase. During the evaluation phase, captured waveform measurements/device states 337 are received by themachine learning module 333, for example via an input port/signal analysis circuit in the case of a waveform or via the signal analysis circuits and/or memory in the case of a device state. Eachclassifier 335 is applied to the measurements/states 337. Theclassifiers 335 each indicate a match or lack of match. In some aspects, theclassifiers 335 also return a confidence value. The measurements/states 337 received during the evaluation phase may contain virtually any type of data, and the classifications are unknown. Accordingly, a classification is determined if only oneclassifier 335 returns a match. If noclassifiers 335 return a match, or ifmultiple classifiers 335 return a match, then thesystem 300 is unable to classify the incoming signal. In the event the measurements/states 337 are matched to asingle classifier 335, the classification (e.g. waveform or bus type) is forwarded to therecommender 339. - The
recommender 339 is a component configured to recommend particular actions or measurements to a user. Therecommender 338 receives the classification and obtains thecorresponding model 336. Based on themodel 336 returned, therecommender 338 can recommend particular measurements that a user may find useful for the classifications, such as useful trigger points, particular transforms, etc. that are relevant to the classified waveform or bus. Further, therecommender 338 can recommend particular actions that a user may wish to take based on the classification, such as selecting configuring a bus, changing display ranges, etc. In addition, therecommender 338 may also reorder lists of suggested actions/measurements so the most relevant actions/measurements for the particular classification are listed first. Also, therecommender 338 may grey out or remove actions/measurements that are unsuited for a particular classification. Therecommender 338 then sends such suggestions to the user via anoutput 339, which may include a display such asdisplay 111/211. The user may the employ the controls (e.g. controls 113/213) to accept or reject the suggestions. In some aspects, therecommender 338 may also take any suggested action or initiate any suggested measurements immediately without requiring direct user initiation, approval, or interaction. -
FIG. 4 is a block diagram illustrating an embodiment of machine learning objects 400 includingclassifier 435 andmodel data 436 objects.Classifier 435 andmodel 436 are substantially similar toclassifiers 335 andmodels 336, respectively.Classifier 435 is an example of aclassifier 335 configured to implement a random forest machine learning algorithm.Classifier 435 includes adecision forest 441, which further includes a plurality ofdecision trees 443. Specifically, adecision forest 441 is created for each classification (e.g. as discussed with respect to classifier 335). During training,decision trees 443 are grown in thedecision forest 441 based on the training data. Various signal qualities are employed by thedecision trees 443 to classify the training data, as discussed above, and thedecision trees 443 are corrected when an incorrect result is returned (e.g. improper match or improper lack of match). In some aspects, one hundreddecision trees 443 are employed in adecision forest 441. Randomization is employed to reduce the occurrence of overfitting of thedecision trees 443 to the training data set. Upon completion of the learning phase, aconfidence threshold 445 may be stored to eachclassifier 435. Aconfidence threshold 445 indicates a minimum percentage ofdecision trees 443 in thedecision forest 441 that should output a positive classification (e.g. return a match) to result in a positive classification for thecorresponding decision forest 441 andcorresponding classifier 435. For example, aconfidence threshold 445 of eighty percent may be used to indicate that eighty percent of thedecision trees 443 should indicate a match before the system is confident that a match has actually been found. Further, cross-validation may be employed to evaluate the accuracy of thedecision forest 441 with respect to the training data set. The cross-validation results may be employed to further correct the output of the decision forest relative to the training data. - During the evaluation phase, measurement data is received via an input port and forwarded to the processor. The processor applies each of the
classifiers 435 to the measurement data to determine a classification for the measurement data. When a selectedclassifier 435 is applied, thedecision forest 443 applies eachdecision tree 443 and receives an output. Theclassifier 435 employs the percentage ofdecision tree 443 outputs that report a match as aconfidence value 447. When theconfidence value 447 output by thedecision forest 441 exceeds aconfidence threshold 445 of theclassifier 435, thedecision tree 441 and hence theclassifier 435 is considered to have returned a match. - As shown, each
classifier 435 corresponds with amodel 436 that indicates suggestedmeasurements 444 and suggestedactions 446 associated with the classification of theclassifier 435. When aclassifier 435 returns a match, as indicated by aconfidence value 447 in excess of theconfidence threshold 445, the recommender selects themodel 436 corresponding to the classification to obtain the corresponding suggestedmeasurements 444 and/or suggestedactions 446. The recommender can then configure the test and measurement instrument to employ the suggestedmeasurements 444 and/or suggestedactions 446 corresponding to the selectedmodel 436 when capturing a waveform received over the input port. As noted above, suggestedmeasurements 444 and/or suggestedactions 446 are set during the learning phase to suggest intuitive actions for the user.Suggested measurements 444 may include sorting, enabling, highlighting, and/or hiding any of the measurements listed with respect toclassifier 335 on the display.Suggested actions 446 may include sorting, enabling, highlighting, and/or hiding any of the bus categories listed with respect toclassifier 335 on the display. -
FIG. 5 is a block diagram illustrating an embodiment of amethod 500 of implementing a learning phase in a test and measurement system.Method 500 may be employed by an oscilloscope, such asoscilloscope 100/200 operating a test and measurement system, such assystem 300 with data structures such as machine learning objects 400. Atblock 501, training data, such astraining data 331, is received, for example via an input port. The training data represents waveforms and/or buses and may also include corresponding known classifications. Atblock 503, a processor employs a machine learning algorithm to train the classifiers on the training data based on the known classifications. Specifically, each classifier is iteratively applied to each waveform of the training data to obtain corresponding predicted waveform classifications. The predicted waveform classifications are compared with the known classifications. Further, each classifier that outputs a predicted waveform classification that does not match the known classification for the corresponding waveform is corrected. By iteratively testing and correcting each classifier, the classifiers progressively become more accurate when attempting classification of new input data. Atblock 505, confidence thresholds may optionally be stored for the classifiers. For example, decision forest based classifiers may employ confidence thresholds, while other learning algorithms may not employ confidence thresholds and may instead return only a match (e.g. a classification) or a lack of a match (no classification) for each classifier. Models, such asmodels 436, are generated atblock 507. Sets of suggested measurements and/or suggested actions are added to each model. The suggested measurements/actions include instructions executed by the test and measurement system upon matching measurement data with a classification of a classifier corresponding to the model. For example, suggested measurements associated with waveform classification are stored to a classifier corresponding to waveform classification, and suggested actions associated with bus classification are stored to a classifier corresponding to bus classification. Atblock 509, cross validation of the training data is employed to evaluate the accuracy of and/or further correct the classifiers. Cross validation may be performed on both waveform based training data and bus based training data. -
FIG. 6 is a block diagram illustrating an embodiment of amethod 600 of implementing an evaluation phase in a test and measurement system.Method 600 may be employed by an oscilloscope, such asoscilloscope 100/200 operating a test and measurement system, such assystem 300 with data structures such as machine learning objects 400. Specifically,method 600 may be employed after the training ofmethod 500 is completed. Atblock 601, measurement data is received, for example via an input port. The received measurement data corresponds to a measured waveform or bus input, and is received for purposes of classification. Atblock 602, each of the classifiers are applied to the measurement data to determine a classification, for example for a measured waveform or bus input. The classifiers each return a classification by examining signal amplitude, time characteristics, jitter, power, etc. as described above. Atblock 603, a confidence value is produced for some or all of the classifiers to support determination of a classification. Atblock 605, the confidence values of the classifiers are compared to their respective confidence thresholds to determine whether a single classifier produces a confidence value in excess of a corresponding stored confidence threshold. If two classifiers return a match, then classification is unclear. If no classifier returns a match, then classification is not possible. In either case, themethod 600 proceed to block 609. In such a case, classification is unsuccessful. The result may be displayed on the test and measurement system display and no action is taken. If a single classifier returns a confidence value in excess of a corresponding confidence threshold, then classification of a waveform type or bus type is successful and themethod 600 proceeds to block 607. A model corresponding to the classifier returning the determined classification is selected, for example by the recommender. As noted above the model corresponds to suggested measurements and/or actions for the classifier. The recommender implements the suggested measurements and/or actions by configuring the test and measurement instrument to employ the suggested measurements/actions corresponding to the selected model when capturing the measured waveform, for example upon approval by the user via controls. The recommender can either display the suggested actions/measurements to the user on the display by emphasizing or deemphasizing the suggestions, removing actions/measurements from the display that are irrelevant to the determine classification, or by preparing the test and measurement system to perform the actions upon receiving approval from the user. Feature selection may also be employed on each classifier's classification by reducing a corresponding set of classifier inputs in the models by removing inputs that are not useful for the corresponding classification. Accordingly, theoscilloscope 100/200 operating test andmeasurement system 300 withdata objects 400 according to methods 500-600 improve the functionality of an oscilloscope by allowing the oscilloscope to classify inputs to the oscilloscope and alter the oscilloscope display accordingly to emphasize or de-emphasize device functions that are relevant to the user. Hence the devices, systems, and methods disclosed herein allow the user to access relevant functions much more easily and clearly the other systems. - Embodiments of the invention may operate on a particularly created hardware, on firmware, digital signal processors, or on a specially programmed general purpose computer including a processor operating according to programmed instructions. The terms “controller” or “processor” as used herein are intended to include microprocessors, microcomputers, ASICs, and dedicated hardware controllers. One or more aspects of the invention may be embodied in computer-usable data and computer-executable instructions, such as in one or more program modules, executed by one or more computers (including monitoring modules), or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types when executed by a processor in a computer or other device. The computer executable instructions may be stored on a non-transitory computer readable medium such as a hard disk, optical disk, removable storage media, solid state memory, RAM, etc. As will be appreciated by one of skill in the art, the functionality of the program modules may be combined or distributed as desired in various embodiments. In addition, the functionality may be embodied in whole or in part in firmware or hardware equivalents such as integrated circuits, field programmable gate arrays (FPGA), and the like. Particular data structures may be used to more effectively implement one or more aspects of the invention, and such data structures are contemplated within the scope of computer executable instructions and computer-usable data described herein.
- The previously described versions of the disclosed subject matter have many advantages that were either described or would be apparent to a person of ordinary skill. Even so, all of these advantages or features are not required in all versions of the disclosed apparatus, systems, or methods.
- Additionally, this written description makes reference to particular features. It is to be understood that the disclosure in this specification includes all possible combinations of those particular features. For example, where a particular feature is disclosed in the context of a particular aspect or embodiment, that feature can also be used, to the extent possible, in the context of other aspects and embodiments.
- Also, when reference is made in this application to a method having two or more defined steps or operations, the defined steps or operations can be carried out in any order or simultaneously, unless the context excludes those possibilities.
- Although specific embodiments of the invention have been illustrated and described for purposes of illustration, it will be understood that various modifications may be made without departing from the spirit and scope of the invention. Accordingly, the invention should not be limited except as by the appended claims.
Claims (16)
Priority Applications (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/262,406 US10585121B2 (en) | 2016-09-12 | 2016-09-12 | Recommending measurements based on detected waveform type |
JP2017173708A JP7096653B2 (en) | 2016-09-12 | 2017-09-11 | How to train a test measuring device and a test measuring device to propose a measurement |
CN201710816657.9A CN107818331A (en) | 2016-09-12 | 2017-09-12 | Measurement is recommended based on the type of waveform detected |
EP22190041.8A EP4109113B1 (en) | 2016-09-12 | 2017-09-12 | Recommending measurements based on detected waveform type |
EP17190691.0A EP3293528B1 (en) | 2016-09-12 | 2017-09-12 | Recommending measurements based on detected waveform type |
US16/811,753 US11181553B2 (en) | 2016-09-12 | 2020-03-06 | Recommending measurements based on detected waveform type |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/262,406 US10585121B2 (en) | 2016-09-12 | 2016-09-12 | Recommending measurements based on detected waveform type |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/811,753 Continuation US11181553B2 (en) | 2016-09-12 | 2020-03-06 | Recommending measurements based on detected waveform type |
Publications (2)
Publication Number | Publication Date |
---|---|
US20180074096A1 true US20180074096A1 (en) | 2018-03-15 |
US10585121B2 US10585121B2 (en) | 2020-03-10 |
Family
ID=59858596
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/262,406 Active 2037-04-17 US10585121B2 (en) | 2016-09-12 | 2016-09-12 | Recommending measurements based on detected waveform type |
US16/811,753 Active US11181553B2 (en) | 2016-09-12 | 2020-03-06 | Recommending measurements based on detected waveform type |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/811,753 Active US11181553B2 (en) | 2016-09-12 | 2020-03-06 | Recommending measurements based on detected waveform type |
Country Status (4)
Country | Link |
---|---|
US (2) | US10585121B2 (en) |
EP (2) | EP3293528B1 (en) |
JP (1) | JP7096653B2 (en) |
CN (1) | CN107818331A (en) |
Cited By (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10852323B2 (en) * | 2018-12-28 | 2020-12-01 | Rohde & Schwarz Gmbh & Co. Kg | Measurement apparatus and method for analyzing a waveform of a signal |
CN113316776A (en) * | 2018-11-28 | 2021-08-27 | 特克特朗尼克公司 | Classification of collected data based on explicit and implicit ways |
WO2021252869A1 (en) * | 2020-06-11 | 2021-12-16 | Tektronix, Inc. | System and method for multi-level signal cyclic loop image representations for measurements and machine learning |
US20220036238A1 (en) * | 2020-07-30 | 2022-02-03 | Tektronix, Inc. | Mono channel burst classification using machine learning |
US11316542B2 (en) | 2020-08-10 | 2022-04-26 | Rohde & Schwarz Gmbh & Co. Kg | Signal analysis method and signal analysis module |
US20220163566A1 (en) * | 2020-11-23 | 2022-05-26 | Initial State Technologies, Inc. | System and method for high performance distribution of large waveform captures to multiple viewers |
US20220247648A1 (en) * | 2021-02-03 | 2022-08-04 | Tektronix, Inc. | Eye classes separator with overlay, and composite, and dynamic eye-trigger for humans and machine learning |
US11481667B2 (en) * | 2019-01-24 | 2022-10-25 | International Business Machines Corporation | Classifier confidence as a means for identifying data drift |
US11531930B2 (en) * | 2018-03-12 | 2022-12-20 | Royal Bank Of Canada | System and method for monitoring machine learning models |
US11580382B2 (en) | 2019-04-26 | 2023-02-14 | Rohde & Schwarz Gmbh & Co. Kg | Method and apparatus providing a trained signal classification neural network |
US11640523B2 (en) | 2019-01-02 | 2023-05-02 | Rohde & Schwarz Gmbh & Co. Kg | Method for training a neural network, method for automatically characterizing a measurement signal, measurement apparatus and method for analyzing |
US20230386584A1 (en) * | 2022-05-27 | 2023-11-30 | Sandisk Technologies Llc | Systems and methods of correcting errors in unmatched memory devices |
US11923895B2 (en) | 2021-03-24 | 2024-03-05 | Tektronix, Inc. | Optical transmitter tuning using machine learning and reference parameters |
US11923896B2 (en) | 2021-03-24 | 2024-03-05 | Tektronix, Inc. | Optical transceiver tuning using machine learning |
US11940889B2 (en) | 2021-08-12 | 2024-03-26 | Tektronix, Inc. | Combined TDECQ measurement and transmitter tuning using machine learning |
US12146914B2 (en) | 2022-05-16 | 2024-11-19 | Tektronix, Inc. | Bit error ratio estimation using machine learning |
Families Citing this family (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11137323B2 (en) * | 2018-11-12 | 2021-10-05 | Kabushiki Kaisha Toshiba | Method of detecting anomalies in waveforms, and system thereof |
CN109547102B (en) * | 2018-12-17 | 2020-05-29 | 北京邮电大学 | Optical performance monitoring method and device, electronic equipment and readable storage medium |
US11138477B2 (en) * | 2019-08-15 | 2021-10-05 | Collibra Nv | Classification of data using aggregated information from multiple classification modules |
US10749618B1 (en) * | 2019-10-22 | 2020-08-18 | Raytheon Company | Methods of closed-loop control of a radio frequency (RF) test environment based on machine learning |
US11798618B2 (en) * | 2019-11-15 | 2023-10-24 | Rohde & Schwarz Gmbh & Co. Kg | Signal analyzer and method of processing data from an input signal |
US11481584B2 (en) * | 2020-01-15 | 2022-10-25 | Vmware, Inc. | Efficient machine learning (ML) model for classification |
US11526785B2 (en) | 2020-06-22 | 2022-12-13 | Vmware, Inc. | Predictability-driven compression of training data sets |
US11867725B2 (en) | 2020-11-06 | 2024-01-09 | Rohde & Schwarz Gmbh & Co. Kg | Measurement instrument |
JP7545914B2 (en) * | 2021-03-08 | 2024-09-05 | 株式会社豊田中央研究所 | Condition determination device and vehicle |
US11907090B2 (en) | 2021-08-12 | 2024-02-20 | Tektronix, Inc. | Machine learning for taps to accelerate TDECQ and other measurements |
DE112022004038T5 (en) * | 2021-08-20 | 2024-06-20 | Tektronix, Inc. | DIGITAL TWIN USING MACHINE LEARNING WAVEFORM GENERATION INCLUDING PARAMETER CONTROL FOR DUT EMULATION |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5092343A (en) * | 1988-02-17 | 1992-03-03 | Wayne State University | Waveform analysis apparatus and method using neural network techniques |
US5799133A (en) * | 1996-02-29 | 1998-08-25 | British Telecommunications Public Limited Company | Training process |
US6571185B1 (en) * | 1999-04-20 | 2003-05-27 | Tektronix, Inc. | Continually responsive and anticipating automatic setup function for a digital oscilloscope |
US20090281981A1 (en) * | 2008-05-06 | 2009-11-12 | Chen Barry Y | Discriminant Forest Classification Method and System |
US20160125218A1 (en) * | 2014-10-30 | 2016-05-05 | Datalogic IP Tech, S.r.l. | Systems, methods and articles for reading highly blurred machine-readable symbols |
US20160341766A1 (en) * | 2015-05-18 | 2016-11-24 | Fluke Precision Measurement Limited | Method and apparatus for classifying a signal waveform under test |
Family Cites Families (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH05126859A (en) * | 1991-11-08 | 1993-05-21 | Matsushita Electric Ind Co Ltd | Oscilloscope |
KR20010006990A (en) * | 1999-04-20 | 2001-01-26 | 윈켈만 존 디. | Continually responsive and anticipating automatic setup function for a digital oscilloscope |
JP2002162419A (en) * | 2000-10-11 | 2002-06-07 | Agilent Technol Inc | System and method for generating database of pulse characteristics for each pulse of signal caught by signal- measuring system |
US6993440B2 (en) | 2002-04-22 | 2006-01-31 | Harris Corporation | System and method for waveform classification and characterization using multidimensional higher-order statistics |
EP1531478A1 (en) * | 2003-11-12 | 2005-05-18 | Sony International (Europe) GmbH | Apparatus and method for classifying an audio signal |
US7477999B2 (en) | 2006-10-26 | 2009-01-13 | Samplify Systems, Inc. | Data compression for a waveform data analyzer |
US8025425B2 (en) | 2007-06-06 | 2011-09-27 | Trex Enterprises Corp | Beaconless adaptive optics system |
EP2681715B1 (en) * | 2011-03-04 | 2022-07-13 | LBT Innovations Limited | Method and software for analysing microbial growth |
US20160012521A1 (en) | 2014-07-11 | 2016-01-14 | BidAway, Inc. | System and Method for Online Bidding |
US20170231519A1 (en) | 2014-08-19 | 2017-08-17 | The General Hospital Corporation | System and method for annotating and analyzing eeg waveforms |
JP6353747B2 (en) * | 2014-08-29 | 2018-07-04 | 日置電機株式会社 | Waveform recorder |
-
2016
- 2016-09-12 US US15/262,406 patent/US10585121B2/en active Active
-
2017
- 2017-09-11 JP JP2017173708A patent/JP7096653B2/en active Active
- 2017-09-12 EP EP17190691.0A patent/EP3293528B1/en active Active
- 2017-09-12 CN CN201710816657.9A patent/CN107818331A/en active Pending
- 2017-09-12 EP EP22190041.8A patent/EP4109113B1/en active Active
-
2020
- 2020-03-06 US US16/811,753 patent/US11181553B2/en active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5092343A (en) * | 1988-02-17 | 1992-03-03 | Wayne State University | Waveform analysis apparatus and method using neural network techniques |
US5799133A (en) * | 1996-02-29 | 1998-08-25 | British Telecommunications Public Limited Company | Training process |
US6571185B1 (en) * | 1999-04-20 | 2003-05-27 | Tektronix, Inc. | Continually responsive and anticipating automatic setup function for a digital oscilloscope |
US20090281981A1 (en) * | 2008-05-06 | 2009-11-12 | Chen Barry Y | Discriminant Forest Classification Method and System |
US20160125218A1 (en) * | 2014-10-30 | 2016-05-05 | Datalogic IP Tech, S.r.l. | Systems, methods and articles for reading highly blurred machine-readable symbols |
US20160341766A1 (en) * | 2015-05-18 | 2016-11-24 | Fluke Precision Measurement Limited | Method and apparatus for classifying a signal waveform under test |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11531930B2 (en) * | 2018-03-12 | 2022-12-20 | Royal Bank Of Canada | System and method for monitoring machine learning models |
CN113316776A (en) * | 2018-11-28 | 2021-08-27 | 特克特朗尼克公司 | Classification of collected data based on explicit and implicit ways |
US10852323B2 (en) * | 2018-12-28 | 2020-12-01 | Rohde & Schwarz Gmbh & Co. Kg | Measurement apparatus and method for analyzing a waveform of a signal |
US11640523B2 (en) | 2019-01-02 | 2023-05-02 | Rohde & Schwarz Gmbh & Co. Kg | Method for training a neural network, method for automatically characterizing a measurement signal, measurement apparatus and method for analyzing |
US11481667B2 (en) * | 2019-01-24 | 2022-10-25 | International Business Machines Corporation | Classifier confidence as a means for identifying data drift |
US11580382B2 (en) | 2019-04-26 | 2023-02-14 | Rohde & Schwarz Gmbh & Co. Kg | Method and apparatus providing a trained signal classification neural network |
WO2021252869A1 (en) * | 2020-06-11 | 2021-12-16 | Tektronix, Inc. | System and method for multi-level signal cyclic loop image representations for measurements and machine learning |
US20220036238A1 (en) * | 2020-07-30 | 2022-02-03 | Tektronix, Inc. | Mono channel burst classification using machine learning |
US11316542B2 (en) | 2020-08-10 | 2022-04-26 | Rohde & Schwarz Gmbh & Co. Kg | Signal analysis method and signal analysis module |
US20220163566A1 (en) * | 2020-11-23 | 2022-05-26 | Initial State Technologies, Inc. | System and method for high performance distribution of large waveform captures to multiple viewers |
US20220247648A1 (en) * | 2021-02-03 | 2022-08-04 | Tektronix, Inc. | Eye classes separator with overlay, and composite, and dynamic eye-trigger for humans and machine learning |
US11923895B2 (en) | 2021-03-24 | 2024-03-05 | Tektronix, Inc. | Optical transmitter tuning using machine learning and reference parameters |
US11923896B2 (en) | 2021-03-24 | 2024-03-05 | Tektronix, Inc. | Optical transceiver tuning using machine learning |
US11940889B2 (en) | 2021-08-12 | 2024-03-26 | Tektronix, Inc. | Combined TDECQ measurement and transmitter tuning using machine learning |
US12146914B2 (en) | 2022-05-16 | 2024-11-19 | Tektronix, Inc. | Bit error ratio estimation using machine learning |
US20230386584A1 (en) * | 2022-05-27 | 2023-11-30 | Sandisk Technologies Llc | Systems and methods of correcting errors in unmatched memory devices |
US12100458B2 (en) * | 2022-05-27 | 2024-09-24 | Sandisk Technologies Llc | Systems and methods of correcting errors in unmatched memory devices |
Also Published As
Publication number | Publication date |
---|---|
CN107818331A (en) | 2018-03-20 |
EP3293528A3 (en) | 2018-07-18 |
JP2018059912A (en) | 2018-04-12 |
EP4109113B1 (en) | 2024-05-01 |
EP3293528B1 (en) | 2022-11-23 |
JP7096653B2 (en) | 2022-07-06 |
US10585121B2 (en) | 2020-03-10 |
US11181553B2 (en) | 2021-11-23 |
EP3293528A2 (en) | 2018-03-14 |
EP4109113A1 (en) | 2022-12-28 |
US20200209282A1 (en) | 2020-07-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11181553B2 (en) | Recommending measurements based on detected waveform type | |
US11181552B2 (en) | Categorization of acquired data based on explicit and implicit means | |
US10782348B2 (en) | Automatic device detection and connection verification | |
US11923895B2 (en) | Optical transmitter tuning using machine learning and reference parameters | |
CN106353548B (en) | Method and apparatus for classifying signal waveforms to be measured | |
US20220390515A1 (en) | General digital signal processing waveform machine learning control application | |
US11923896B2 (en) | Optical transceiver tuning using machine learning | |
CN109729546A (en) | Waveform model | |
US20200019855A1 (en) | Data analysis device, data analysis method and data analysis program | |
JP2022179459A (en) | Measurement method and test and measurement system | |
US20210406727A1 (en) | Managing defects in a model training pipeline using synthetic data sets associated with defect types | |
TW202316135A (en) | Machine learning for taps to accelerate tdecq and other measurements | |
JP2023026402A (en) | Test and measurement system and method of testing device under test | |
US20230384084A1 (en) | Method and device for determining an optimized parameter set to perform a measurement | |
US11698849B2 (en) | Automated application testing of mutable interfaces | |
CN115730205A (en) | Method and device for configuring decision device and related equipment | |
US20240369625A1 (en) | Method for separating and modeling n-ui jitter based on spectrum | |
US12146914B2 (en) | Bit error ratio estimation using machine learning | |
US20220373597A1 (en) | Bit error ratio estimation using machine learning | |
TW202413960A (en) | Machine learning for measurement using linear response extracted from waveform | |
WO2024233410A1 (en) | Method for separating and modeling n-ui jitter based on spectrum | |
CN117273164A (en) | Machine learning for measurements using linear responses extracted from waveforms | |
US20190227109A1 (en) | Quantifying random timing jitter that includes gaussian and bounded components | |
TW202413957A (en) | Separating noise to increase machine learning prediction accuracy in a test and measurement system | |
Tymkiv | Adaptation of the neyman-pearson criteria for assessing the reliability of the choice of the method for determining the coefficients of the mathematical model of low-intensity electroretinosignal |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: TEKTRONIX, INC., OREGON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ABSHER, IAN R.;STRONG, KRAIG M.;SIGNING DATES FROM 20160909 TO 20161006;REEL/FRAME:042636/0564 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: ADVISORY ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NOTICE OF ALLOWANCE MAILED -- APPLICATION RECEIVED IN OFFICE OF PUBLICATIONS |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 4 |