slreportgen.report.Bus Class
Namespace: slreportgen.report
Superclasses: slreportgen.report.Reporter
Description
Use an object of the slreportgen.report.Bus class to report on buses that
      are selected or created by Simulink® blocks.
A bus reporter finds buses to report by searching a model, subsystem, block, or signal for
      blocks that select signals from a bus or combine signals to create a bus. For a model or
      subsystem, the Bus reporter reports all of the buses selected or created in the
      model or subsystem. For a block, the reporter reports the bus that is selected or created by
      the block. For a signal, the reporter reports all of the buses selected or created by the
      blocks that are connected to the port specified by the signal. Use the Object property
      to specify the model, subsystem, block, or signal for which to report buses.
By default, a Bus reporter generates:
- A hierarchical list of the signals in the bus 
- A table with details about the selected signals or the signals used to create the bus 
- Paragraphs with details about bus objects and connected blocks for each bus-related block found 
 Use the reporter properties to customize the content and appearance of the generated
      report. For example, use the ReportedBlockType property to specify which
      types of blocks to use when searching for buses.
Note
To use an slreportgen.report.Bus reporter in a report, you must create
          the report using the slreportgen.report.Report class or subclass.
The slreportgen.report.Bus class is a handle class.
Creation
Description
busRptr = slreportgen.report.Bus(Name=Value)Bus object properties
          using name-value arguments. You can specify multiple name-value arguments in any order.
Properties
Model, block, or signal to search for buses, specified as one of the following values:
- character vector or string scalar that contains the name of a model, Subsystem block, Bus Creator block, Bus Assignment block, or Bus Selector block 
- Handle of a model, Subsystem block, Bus Creator block, Bus Assignment block, or Bus Selector block 
- Handle of a block input or output port connected to a signal 
- slreportgen.finder.DiagramResult,- slreportgen.finder.BlockResult, or- slreportgen.finder.SignalResultobject
Title for each reported bus, specified as a string scalar, character vector, DOM object, or function handle. The contents of this property are reported with each bus included by the reporter. If this property is empty, no title is reported.
If this property contains text or a function handle that returns text, the text is
            added to an mlreportgen.dom.Paragraph object with the
              style BusTitleParagraph.
 If this property is specified as a function handle, the function must return
            content that can be added to a report, such as a string scalar, character vector, or DOM
            object. The function must accept a struct with these fields:
- PortHandle— Handle to the input port or output port of the bus signal. For In Bus Element and Out Bus Element blocks in a subsystem, this field is the port handle of the subsystem that corresponds to the blocks. For In Bus Element and Out Bus Element blocks in the top level of a model, this field is- -1.
- BlockName— Name of reported model, Bus Creator, Bus Selector, Bus Assignment, or Subsystem block that creates or selects the reported bus, specified as a string scalar.
- BlockPath— Full path of model, Bus Creator, Bus Selector, Bus Assignment, or Subsystem block that creates or selects the reported bus, specified as a string scalar.
- BusPortString— For a bus created or selected by a model or subsystem port, this field contains the input port or output port connected to the bus signal, specified as a string scalar. For example,- "Inport <x>". Otherwise, this field is an empty string (- "").
For example: busRptr.Title = @(blkInfo)
              blkInfo.BlockName;
Types of blocks used to report bus information, specified as one of these values:
- "auto"— Reports bus information from Bus Creator, Bus Assignment, and Out Bus Element blocks if the input is a Bus Creator, Bus Assignment, or Out Bus Element block. Otherwise, reports bus information from Bus Selector and In Bus Element blocks.
- "all"— Reports bus information from all supported bus-related block types.
- List of block types, specified as a string array or a cell array of character vectors. Valid block types are: - BusCreator 
- BusSelector 
- BusAssignment 
- Inport 
- Outport 
 - For example: - ["BusCreator","BusSelector"]
For models or subsystems, the Bus reporter reports bus information
            from all blocks of the types that this property specifies. For signals, the reporter
            reports bus information from all blocks of the specified types that are connected to the
            signal (source and destination). For blocks, this property is used only if the
               IncludeNestedBuses property is
              true. For Bus Selector and In Bus
              Element blocks, the reporter reports bus information from all blocks of the
            specified type that are connected to the output signals of the block. For Bus
              Creator, Bus Assignment, and Out Bus
            Element blocks, the reporter reports bus information from all blocks of the
            specified type that are connected to the input signals of the block.
Whether to report nested buses, specified as true or
              false. If this property is true, the reporter
            reports bus-related blocks of the type specified
              by ReportedBlockType that are connected to the selected signals
            or to signals used to create a bus. If this property is false and
              Object is a block, the reporter reports only the block specified
            by Object. If this property is false and
              Object is a signal, the reporter reports only the blocks directly
            connected to the signal.
If Object is a model or subsystem, this property has no effect
            because all blocks of the type specified by the ReportedBlockType
            property are used to report buses.
Whether to report the hierarchy of bus signals for each bus, specified as
              true or false. If this property is
              true, the reporter includes a list of the names of signals in the
            bus. For blocks that create buses, the list describes the signal hierarchy of the output
            bus. For blocks that select signals from buses, the list describes the signal hierarchy
            of the input bus. If the bus includes any nested signals, the signal names are included
            as a nested list.
The reporter does not include the signal hierarchy for buses created or selected by top-level model input or output ports.
Whether to report details of signals, specified as true or
              false. If this property is true, the reporter
            includes a table describing the signals selected from a bus or used to create a bus,
            depending on the block type.
Whether to report the name of a Simulink.Bus object that is
            associated with the reported bus, specified as true or
              false. If this property is true and the reported
            bus is described by a Simulink.BusObject, the report includes the name of
            the bus object and links the name to the bus object information reported elsewhere in
            the report.
The reporter does not include the bus object name for buses created or selected by top-level model input or output ports.
Whether to report the names of blocks connected to each full bus signal, specified
            as true or false. If this property is
              true:
- For blocks that create buses, the reporter reports the names of the blocks connected to the port that outputs the full bus signal. 
- For blocks that select bus signals, the reporter reports the name of the block from which the full bus signal is output. 
- If - IncludeBusLinksis- true, a- Bus Createdor- Signals Selectedlink is included after the names of blocks that match the block types specified by- ReportedBlockType.
The reporter does not include the names of connected blocks for buses created or selected by top-level model input or output ports.
Whether to include a link to a bus created or selected by a connected block,
            specified as true or false. If this property is
              true, the reporter includes a link to the bus information for
            blocks that are reported as a source or destination in the signal table or connected
            blocks sections. For blocks whose block types are included in
              ReportedBlockTypes, a Bus
              Created or Signals Selected link is
            included next to the block name.
Whether to report block names as links to block details, specified as
              true or false. If this property is
              true, a block name in a signal table title links to the block
            details reported elsewhere in the report.
Whether to report port numbers as links to signal details, specified as
              true or false. If this property is
              true, the reporter reports signal port numbers in the signal table
            as links to the signal details reported elsewhere in the report.
Properties to report for the signals selected by Bus Selector or In Bus Element blocks, specified as a string array or a cell array of character vectors. Specify any of these properties:
- Outport
- Name
- DataType
- Destination
- Description
- Complexity
- Dimensions
- Min
- Max
Properties to report for the signals used to create a bus by Bus Creator, Bus Assignment, and Out Bus Element blocks, specified as a string array or a cell array of character vectors. Specify any of these properties:
- Inport
- Name
- DataType
- Source
- Description
- Complexity
- Dimensions
- Min
- Max
Whether to show empty columns in a signal table, specified as
              true or false.
Function or expression to filter signals in a signal table, specified as a function handle, string scalar, or character vector. Specify a function as a function handle. Specify an expression as a character vector or string scalar. The function or code is executed for each signal that is selected or used to create a bus.
 If TaskFilterFcn is empty, all tasks are included in the
            report.
If you provide a function handle, the associated function must:
- Take these arguments: - portHandle— Handle to port of the selected signal or signal used to create the bus.
- parentPath— Full path of parent block used to report bus information, specified as a string scalar.
- sourcePath— Full path of the source block of the signal, specified as a string scalar.
- destinationPath— Full path of the destination block of the signal. If there are multiple destinations, this argument is a string array of destination blocks.
 
- Return - trueto filter the specified signal from the report, or- falseto include the task in the report.
For example, this code uses the SignalFilterFcn property to
            filter out the signals that feed into the Display3
            block:
import slreportgen.report.* import mlreportgen.report.* model_name = "sldemo_bus_arrays"; load_system(model_name); rpt = slreportgen.report.Report("Bus_example","pdf"); append(rpt,slreportgen.report.Diagram(model_name)); ch = Chapter("Buses"); busRptr = Bus(model_name); busRptr.SignalFilterFcn = @(~, ~, ~, destinationPath) endsWith(destinationPath,"Display3"); append(ch,busRptr); append(rpt,ch); close(rpt); rptview(rpt);
If you provide a string scalar or a character vector, it must contain an expression. The expression:
- Can use the variables - portHandle,- parentPath,- sourcePath, and- destinationPath
- Must set the variable - isFilteredto- trueto filter the specified task from the report, or- falseto include the task in the report
For example, this code uses the SignalFilterFcn property to
            filter out the signals that feed into the Display4 block: 
import slreportgen.report.* import mlreportgen.report.* model_name = "sldemo_bus_arrays"; load_system(model_name); rpt = slreportgen.report.Report("Bus_example","pdf"); append(rpt,slreportgen.report.Diagram(model_name)); ch = Chapter("Buses"); busRptr = Bus(model_name); filterStr = "isFiltered = endsWith(destinationPath,""Display4"");"; busRptr.SignalFilterFcn = filterStr; append(ch,busRptr); append(rpt,ch); close(rpt); rptview(rpt);
Formatter for signal table, specified as an mlreportgen.report.BaseTable object. The default value of this property is a
              BaseTable object with the TableStyleName property
            set to the BusTable style, which is defined in the default template
            for a Bus reporter. To customize the appearance of the table, modify the
            properties of the default BaseTable object or replace the object with
            your own BaseTable object. If you add content to the
              Title property of the BaseTable object, the
            content appears in front of the table title in the generated report.
 Formatter for the signal hierarchy list, specified as an mlreportgen.dom.OrderedList or mlreportgen.dom.UnorderedList object. The formatter reports and formats the
            signal hierarchy list if the ShowSignalHierarchy property of this
              Bus reporter is true. The OrderedList
            or UnorderedList object must not contain list items.
The default value of this property is an UnorderedList object with
            the StyleName property set to the BusList style,
            which is defined in the default template for a Bus reporter. To customize
            the appearance of the list, modify the properties of the default
              UnorderedList object or replace the object with your own
              UnorderedList or OrderedList object.
Paragraph formatter to report and format the connected blocks and bus object
            details, specified as an mlreportgen.dom.Paragraph object. The
            default value of this property is an mlreportgen.dom.Paragraph object with the StyleName
            property set to the BusParagraph style, which is defined in the
            default template for a Bus reporter. To customize the appearance of the
            paragraph, modify the properties of the default mlreportgen.dom.Paragraph
            object or replace the object with a customized mlreportgen.dom.Paragraph
            object. If you add content to the default or replacement paragraph object, the content
            appears in front of the content reported for the connected blocks and bus object details
            in the generated report.
Source of the template for this reporter, specified in one of these ways:
- Character vector or string scalar that specifies the path of the file that contains the template for this reporter 
- Reporter or report whose template this reporter uses or whose template library contains the template for this reporter 
- Document Object Model (DOM) document or document part whose template this reporter uses or whose template library contains the template for this reporter 
The specified template must be the same type as the report to which you
            append this reporter. For example, for a Microsoft® Word report, TemplateSrc must be a Word reporter template.
            If the TemplateSrc property is empty, this reporter uses the
            default reporter template for the output type of the report.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
| NonCopyable | true | 
Name of the template for this reporter, specified as a character vector or string scalar.
      The template for this reporter must be in the template library of the template specified by
      the TemplateSrc property of this reporter.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
Data Types: char | string
Hyperlink target for this reporter, specified as a character vector or string scalar
            that specifies the link target ID, or an mlreportgen.dom.LinkTarget object. A character vector or string scalar
            value converts to a LinkTarget object. The link target immediately
            precedes the content of this reporter in the output report.
Attributes:
| GetAccess | public | 
| SetAccess | public | 
Methods
| slreportgen.report.Bus.createTemplate | Create bus reporter template | 
| slreportgen.report.Bus.customizeReporter | Create subclass of slreportgen.report.Busclass | 
| slreportgen.report.Bus.getClassFolder | Get location of folder that contains the slreportgen.report.Busclass definition file | 
| copy | Create copy of a Simulink reporter object and make deep copies of certain property values | 
| getImpl | Get implementation of reporter | 
Examples
Use an slreportgen.report.Bus object to report on the buses that are selected by the blocks in a model. 
Import the Report API packages so that you do not have to use long fully qualified class names.
import mlreportgen.report.* import slreportgen.report.*
Load the model.
model_name = "sldemo_bus_arrays";
load_system(model_name);Create a Simulink report.
rpt = slreportgen.report.Report("Bus_example","pdf");
Add the diagram of the model to the report.
append(rpt,slreportgen.report.Diagram(model_name));
Report the bus information for the model in a chapter.
ch = Chapter("Buses");
busRptr = Bus(model_name);Use the block name as the title for each block bus.
busRptr.Title = @(blkInfo) blkInfo.BlockName;
Add the bus reporter to the chapter.
append(ch,busRptr);
Add the chapter to the report.
append(rpt,ch); close(rpt); rptview(rpt);
Version History
Introduced in R2021a
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select: .
You can also select a web site from the following list
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)