US20180074096A1 - Recommending measurements based on detected waveform type - Google Patents

Recommending measurements based on detected waveform type Download PDF

Info

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
Application number
US15/262,406
Other versions
US10585121B2 (en
Inventor
Ian R. Absher
Kraig M. Strong
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Tektronix Inc
Original Assignee
Tektronix Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Tektronix Inc filed Critical Tektronix Inc
Priority to US15/262,406 priority Critical patent/US10585121B2/en
Assigned to TEKTRONIX, INC. reassignment TEKTRONIX, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ABSHER, IAN R., STRONG, KRAIG M.
Priority to JP2017173708A priority patent/JP7096653B2/en
Priority to EP17190691.0A priority patent/EP3293528B1/en
Priority to EP22190041.8A priority patent/EP4109113B1/en
Priority to CN201710816657.9A priority patent/CN107818331A/en
Publication of US20180074096A1 publication Critical patent/US20180074096A1/en
Priority to US16/811,753 priority patent/US11181553B2/en
Publication of US10585121B2 publication Critical patent/US10585121B2/en
Application granted granted Critical
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G01MEASURING; TESTING
    • G01RMEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
    • G01R13/00Arrangements for displaying electric variables or waveforms
    • G01R13/20Cathode-ray oscilloscopes
    • G01R13/22Circuits therefor
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F18/00Pattern recognition
    • G06F18/20Analysing
    • G06F18/21Design or setup of recognition systems or techniques; Extraction of features in feature space; Blind source separation
    • G06F18/214Generating training patterns; Bootstrap methods, e.g. bagging or boosting
    • G06F18/2148Generating training patterns; Bootstrap methods, e.g. bagging or boosting characterised by the process organisation or structure, e.g. boosting cascade
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01RMEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
    • G01R13/00Arrangements for displaying electric variables or waveforms
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01RMEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
    • G01R13/00Arrangements for displaying electric variables or waveforms
    • G01R13/02Arrangements for displaying electric variables or waveforms for displaying measured electric variables in digital form
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01RMEASURING ELECTRIC VARIABLES; MEASURING MAGNETIC VARIABLES
    • G01R23/00Arrangements for measuring frequencies; Arrangements for analysing frequency spectra
    • G01R23/16Spectrum analysis; Fourier analysis
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F18/00Pattern recognition
    • G06F18/20Analysing
    • G06F18/24Classification techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N20/00Machine learning
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N20/00Machine learning
    • G06N20/20Ensemble learning
    • G06N7/005
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N7/00Computing arrangements based on specific mathematical models
    • G06N7/01Probabilistic 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

An oscilloscope including an input port for receiving training data including waveforms and corresponding known classifications and a processor for training a plurality of classifiers on the training data. Training includes iteratively applying each classifier to each waveform of the training data to obtain corresponding predicted waveform classifications and comparing the predicted waveform classifications with the known classifications. Classifiers are corrected when predicted waveform classifications does not match the known classifications. Models for each classification are constructed with suggested measurements or actions. Subsequently, live waveform data is captured by the oscilloscope and the classifiers are applied to the live data. When a confidence value for a single classification exceeds a threshold, the waveform data is classified, and suggested measurements or actions are implemented in the oscilloscope based on the classification.

Description

    FIELD OF THE INVENTION
  • 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.
  • BACKGROUND
  • 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.
  • SUMMARY OF THE DISCLOSURE
  • 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.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • 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.
  • DETAILED DESCRIPTION
  • 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 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. 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 the oscilloscope 110 as measurement 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 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. 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. 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. 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 the display 111 as a result of such classifications. It should be noted that 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. For example, 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. 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. For example, 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. As such, machine learning module 216 is configured to perform methods 500, 600, and/or any other methods discussed herein. In some aspects, 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. Accordingly, 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. In some aspects, 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. Accordingly, 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 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 of machine learning module 333.
  • During a learning phase, 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. For example, 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. For example, when training data 331 consistent with a sine wave is forwarded to each classifier 335, 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). 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, 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. As a wide variety of training data and classifications types may be employed by classifiers 335, a plurality of 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. Hence, measurements that are highly determinative for some classifications may not be useful for other classifications. Accordingly, 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. Accordingly, each model 336 describes the measurements the corresponding classifier 335 can accept as input. Further, 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.
  • 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. For example, 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. 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 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. If no classifiers 335 return a match, or if multiple classifiers 335 return a match, then the system 300 is unable to classify the incoming signal. In the event the measurements/states 337 are matched to a single classifier 335, the classification (e.g. waveform or bus type) 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. Also, 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. In some aspects, 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). In some aspects, 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. Upon completion of the learning phase, 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. For example, 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. Further, 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.
  • 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 selected classifier 435 is applied, 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. When 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.
  • As shown, 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. When a classifier 435 returns a match, as indicated by a confidence value 447 in excess of the confidence threshold 445, 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. As noted above, 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. At block 501, training data, such as training 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. At block 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. At block 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 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. At block 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 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. Specifically, method 600 may be employed after the training of method 500 is completed. At block 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. At block 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. At block 603, a confidence value is produced for some or all of the classifiers to support determination of a classification. At block 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, 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. 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 the method 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, 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. 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)

We claim:
1. A test and measurement instrument comprising:
an input port configured to receive measurement data;
a processor coupled to the input port and configured to:
apply a plurality of classifiers to the measurement data to determine a classification for the measurement data;
select a model corresponding to the classification, the model corresponding to one or more suggested measurements; and
configure the test and measurement instrument to employ the suggested measurements corresponding to the selected model when capturing a waveform received over the input port.
2. The test and measurement instrument of claim 1, wherein the plurality of classifiers includes at least one decision forest, and wherein the decision forest determines the classification of the measurement data when a confidence value output by the decision forest exceeds a confidence threshold of the classifier.
3. The test and measurement instrument of claim 1, wherein the plurality of classifiers employ a plurality of machine learning algorithms with specified machine learning algorithms selected to classify particular waveform types.
4. The test and measurement instrument of claim 1, wherein the classifiers determine a classification for the measurement data by examining signal amplitude, time characteristics, jitter, or power.
5. The test and measurement instrument of claim 1, wherein the model corresponding to the classification indicates a type of waveform incoming over the input port.
6. The test and measurement instrument of claim 1, wherein the model corresponding to the classification indicates a bus connected to the input port.
7. The test and measurement instrument of claim 1, further comprising a display, wherein the processor is further configured to suggest actions corresponding to the selected model by altering the display to enable or disable user selections.
8. The test and measurement instrument of claim 1, wherein the processor is further configured to initiate suggested actions without direct user interaction.
9. A method for training a test and measurement instrument to suggest measurements, the method comprising:
receiving training data including waveforms and corresponding known classifications via an input port; and
training, via a processor, a plurality of classifiers on the training data by:
iteratively applying each classifier to each waveform of the training data to obtain corresponding predicted waveform classifications;
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.
10. The method of claim 9, wherein the classifiers include a decision forest, and wherein training the classifiers involves growing decision trees in the decision forest.
11. The method of claim 10, further comprising storing a confidence threshold to each classifier, the confidence threshold indicating a minimum percentage of decision trees in the decision forest that output a positive classification to result in a positive classification for the corresponding classifier.
12. The method of claim 9, further comprising employing cross validation of the training data of waveforms to further correct the classifiers.
13. The method of claim 9, further comprising employing feature selection on each classifier to reduce a corresponding set of classifier inputs by removing inputs that are not useful for the corresponding classification.
14. The method of claim 13, further comprising storing a set of one or more suggested actions to each model, the suggested actions including instructions executed by the test and measurement system upon matching measurement data with a classification of a classifier corresponding to the model.
15. The method of claim 9, further comprising:
receiving measurement data corresponding to a measured waveform or bus input;
applying each of the classifiers to the measurement data to determine a classification for the measured waveform;
selecting a model corresponding to the classifier returning the determined classification, the model corresponding to one or more suggested measurements for the classifier; and
configuring the test and measurement instrument to employ the suggested measurements corresponding to the selected model when capturing the measured waveform.
16. The method of claim 15, wherein determining the classification for the measured waveform includes producing a confidence value for each of the classifiers, and wherein the classification is determined when a single classifier produces a confidence value in excess of a stored confidence threshold.
US15/262,406 2016-09-12 2016-09-12 Recommending measurements based on detected waveform type Active 2037-04-17 US10585121B2 (en)

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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Patent Citations (6)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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