Major Bug Fixes

This document describes major bug fixes for the following:

Communications Blockset

Click on a problem area listed below to read how it has been fixed.

Fading channels
List of demos for which code can now be generated using Real Time Workshop
Passband FSK and CPM modulators and demodulators are more accurate
Reed-Solomon blocks now encode and decode correctly

Fading channels

The accuracy of Doppler spread of the Rayleigh and Rician Fading Channel Blocks has been improved. The blocks now give better results for high sampling rates and small Doppler frequencies, as specified in communication standards such as WCDMA.

List of demos for which code can now be generated using Real Time Workshop

The following demos now generate code using Real Time Workshop:

Passband FSK and CPM modulators and demodulators are more accurate

The passband FSK and CPM modulators have been modified to generate more accurate waveforms by performing FIR interpolation when upsampling. The FIR filters significantly reduce the levels of any spectral copies revealed by upsampling. They also introduce delay into the modulators.

Reed-Solomon blocks now encode and decode correctly

The Reed-Solomon blocks now encode and decode signals correctly.

Communications Toolbox

Click on a problem area listed below to read how it has been fixed.

Reed-Solomon decoder corrects up to t errors
Reed-Solomon encoder and decoder use more conventional format for data

Reed-Solomon decoder corrects up to t errors

The new function rsdec accurately decodes Reed-Solomon codes containing up to t errors in each codeword. This new function replaces the earlier functions rsdeco and rsdecode.

Reed-Solomon encoder and decoder use more conventional format for data

The new functions rsenc and rsdec operate on the new Galois data type, which represents symbols using a decimal format. The formats used in the earlier functions, rsenco, rsencode, rsdeco, and rsdecode, are no longer supported. See "Updating Existing Reed-Solomon M-Code" in the Release Notes to learn how to convert your existing code data to the format used in the new coding functions.

Also, the new functions enable you to choose whether parity bits appear at the beginning or end of each codeword.

Database Toolbox

Click on a problem area listed below to read how it has been fixed.

Improved speed of insert function
Oracle tables load faster in Visual Query Builder
Returning numeric arrays from fetch is faster
Stored procedure now returns data as expected

Improved speed of insert function

The insert function should perform approximately five (or more) times faster than in the previous version.

Oracle tables load faster in Visual Query Builder

In the Visual Query Builder, when you select an Oracle data source, the tables load more quickly than in the previous version of the Database Toolbox.

Returning numeric arrays from fetch is faster

When the data return format is set to numeric in setdbprefs or in preferences, running fetch returns data more quickly than in the previous version.

Stored procedure now returns data as expected

In Version 2.2, running exec with a stored procedure did not return results for some configurations. The problem has been fixed for this version.

DSP Blockset

Cumulative Sum block behaves properly for frame-based inputs

The Cumulative Sum block now behaves properly when given frame-based inputs and set to sum along columns.

In this situation, the block now computes the running sum of each column of a frame-based input, where the running sum is independent of the running sums of previous inputs.

To get the previous behavior for frame-based inputs when set to sum along columns, set the block to sum along channels.

Embedded Target for TI C6000 DSP

Sum, Gain, Mult blocks fast replacement TLC is now Big-endian compatible

Sum, Gain, Mult blocks fast replacement TLC is now Big-endian compatible. They now return correct numeric results.

Filter Design Toolbox

Click on a problem area listed below to read how it has been fixed.

firlpnorm help text was incorrect
QFILT's sos method no longer embeds filter gain in each section
QFILT's sos method no longer normalizes the filter after converting it to SOS

firlpnorm help text was incorrect

For Release 13, the online help text for filter design function firlpnorm is now correct.

QFILT's sos method no longer embeds filter gain in each section

The QFILT sos method no longer embeds the filter gain in each section. It now puts the filter gain into the ScaleValue property of QFILT.

QFILT's sos method no longer normalizes the filter after converting it to SOS

The QFILT sos method no longer normalizes the filter coefficients after converting it to second-order sections, therefore care should be taken to avoid overflows by adjusting the coefficient format of the filter.

Fuzzy Logic Toolbox

Click on a problem area listed below to read how it has been fixed.

addvar and the command line API
Simulink blocks for TRIMF and TRAPMF now correctly handle vertical slopes

addvar and the command line API

In Release 12, addvar systematically initialized the new variable with 3 membership functions, thus breaking the command line API, where it is common first to add the variable and then define the membership functions.

Release 13 adds logic to allow GUIs to create 3 default membership functions without interfering with command line calls.

Simulink blocks for TRIMF and TRAPMF now correctly handle vertical slopes

The cases a-b or b=c in trimmf (a-b and c=d in trapmf) caused Divide by Zero and improper results in Simulink. These blocks have been reimplemented using the IF block to always produce answers consistent with the M file implementation

Image Processing Toolbox

Click on a problem area listed below to read how it has been fixed.

cpselect would ask to save points when it wasn't necessary
Stray points could appear in cpselect in point-prediction mode
dicomread and private data
dicomread and signed data from DICOM files
fspecial 'laplacian' and 'unsharp' options
gray2ind returns the correct output
imadjust no longer errors if passed degenerate inputs
imerode handles binary erosion correctly
imhist on IRIX with input containing NaNs
imnoise with the Poisson option
pixval could give a confusing error message for figures with normalized units
Figures created by imshow
Improved performance of dicomread and dicominfo
legend box is resizable in cpselect
Modified the implementation of the Canny algorithm in the edge function.
RLE decoder for DICOM files

cpselect would ask to save points when it wasn't necessary

When you closed the contol-point selection tool (cpselect), it would ask if you wanted to save control points, even if you had already done so. This has been fixed.

Stray points could appear in cpselect in point-prediction mode

When using the control-point selection tool (cpselect) in point-prediction mode, sometimes a stray control point would appear that could not be deleted. This has been fixed.

dicomread and private data

The dicomread function no longer fails when reading from a file with private data using "explicit VR" syntax.

dicomread and signed data from DICOM files

The dicomread function used no longer fails when reading signed data from pixels which were not "normal" lengths.

fspecial 'laplacian' and 'unsharp' options

The fspecial function now accepts a parameter value of 0 for the 'laplacian' and 'unsharp' options.

gray2ind returns the correct output

If the input image to gray2ind was logical, then the output was also logical. The gray2ind function now returns the correct output in such situations.

imadjust no longer errors if passed degenerate inputs

A call to imadjust with identical low and high limits, such as
imadjust(A,[b b],[]),

caused imadjust to error out. The problem has been fixed by providing default limits when the input limits are degenerate.

imerode handles binary erosion correctly

Prior to Release 13, when performing binary erosion with a decomposed structuring element, such as strel(ones(5,5)), the first 32 rows of the output image could be wrong. This has been fixed.

imhist on IRIX with input containing NaNs

The function imhist no longer causes a segmentation violation on IRIX with input containing NaNs.

imnoise with the Poisson option

The function imnoise now returns a correctly- sized output instead of a column vector when using the Poisson option.

pixval could give a confusing error message for figures with normalized units

Turning on pixval for a figure in normalized units could produce a confusing error message. The pixval function now issues a more informative error message if the figure is not in pixel units.

Figures created by imshow

Prior to Release 13, if invalid input was passed to imshow, it would sometimes error out after creating an invisible figure object. Subsequent calls to imshow would appear to not do anything, because the images were being sent to the invisible figure. The problem has been fixed by adding additional input checking to imshow.

Improved performance of dicomread and dicominfo

The dicomread and dicominfo functions parse files quicker than in the past, especially for files with a lot of metadata.

legend box is resizable in cpselect

The legend box for the control-point selection tool (cpselect) was unresizable, which sometimes caused the title bar to be unreadable. This has been fixed.

Modified the implementation of the Canny algorithm in the edge function.

In the Canny algorithm in the edge function, Gaussian smoothing should be run perpendicular to the direction of differentiation. This has been implemented.

RLE decoder for DICOM files

The RLE decoder used by dicomread used to only work for 8-bit grayscale images (and only for certain ones at that). The decoder now correctly handles all bit depths and image types.

Mapping Toolbox

Click on a problem area listed below to read how it has been fixed.

Computed distances no longer have spurious imaginary part
Coordinates in map legends for regular matrix maps
Fixed incorrect UTM coordinates in the southern hemisphere
Reading ETOPO5 data files at full resolution

Computed distances no longer have spurious imaginary part

The round-off problem that caused the return value of the distance function to include a small, nonzero imaginary part for certain inputs has been fixed.

Coordinates in map legends for regular matrix maps

Version 1.3 fixes setpostn to handle longitude limits that straddle the prime meridian.

Fixed incorrect UTM coordinates in the southern hemisphere

A typographical error in defaultm in the false northing for Universal Transverse Mercator (UTM) has been corrected. That error had caused incorrect UTM/geographic conversions for points in the southern hemisphere.

Reading ETOPO5 data files at full resolution

Padding is added as needed in etopo5 when reading different numbers of elements from the northern and southern hemisphere files.

MATLAB

Click on a problem area listed below to read how it has been fixed.

'cubic' method in griddata no longer produces segmentation fault
diff function has improved handling of negative order
eigs(A,B,k,sigma) for sparse B now converges
filter function has better support for multidimensional data
log10(10^i) now returns i, exactly
lsqr now converges for rectangular systems
sqrtm now returns correct results for singular Hermitian matrix
Array Editor supports more than 10,000 elements
Import Wizard opens large files more quickly
Improved accuracy for denormal pivot handling
Improved Workspace browser performance with many variables
Modal dialog behavior improvements
Serial port fixes
The lookfor function now automatically displays results
Workspace browser allows renaming variables

'cubic' method in griddata no longer produces segmentation fault

Previously, the 'cubic' method of the griddata function would occasionally encounter a segmentation fault. This no longer happens.

diff function has improved handling of negative order

Previously, MATLAB encountered a segmentation fault when computing diff(sparse([1;1]),-1). Now, an error message is displayed if the order is not a real positive integer.

eigs(A,B,k,sigma) for sparse B now converges

Previously,
eigs(A,B,k,sigma)

for sparse B and non-scalar sigma (sigma not equal to 'SM' either) applied a reordering to B before factoring it for use in repeated solves. Unfortunately, the reordering was not correctly applied in the subsequent solves and as a result eigs did not converge.

The reordering is now being applied correctly and eigs now converges in this case.

filter function has better support for multidimensional data

For multidimensional inputs, filter sometimes produced incorrect error messages or the wrong results. This no longer happens.

log10(10^i) now returns i, exactly

Previously, log10 was computed directly as log(x) / log(10), where log is the natural logarithm. The error in this was particularly visible in computations of the form log10(10^i), for example:

>> log10(1e6)
ans =
     5.999999999999999e+00

Now, log10 does some additional scaling to compute log10(10^i) to the nearest bit.

lsqr now converges for rectangular systems

Previously, lsqr only converged for square, consistent systems A*x=b and returned a solution x where norm(b-A*x) was small.

Now, lsqr also converges for rectangular systems and returns a solution x where norm(b-A*x) is not necessarily small, but is minimized, and in fact norm(A'*(b-A*x)) is small.

sqrtm now returns correct results for singular Hermitian matrix

A matrix square root always exists for Hermitian matrices. Previously, sqrtm(X) sometimes returned a matrix of all NaNs for matrices X that were both Hermitian and singular. Now sqrtm(X) returns the correct results for these matrices. sqrtm is now also faster for Hermitian matrices.

Array Editor supports more than 10,000 elements

The Array Editor can now show arrays with more than 10,000 elements. It does not support arrays with more than 65,536 (2^16) elements.

Import Wizard opens large files more quickly

In previous releases, the Import Wizard was sometimes slow when opening large files, but the problem has been fixed in this version.

Improved accuracy for denormal pivot handling

LU factorizations for full matrices now use a modified version of the LAPACK LU factorization routines and return more accurate results when encountering denormal pivots (i.e., smaller than realmin). In previous versions, results may have included NaNs; for example:

A = [2^(-1050) 2^(-1050);0 0] 
[L,U] = lu(A)

A =
    1.0e-316 *
       0.8289  0.8289
            0       0

L =
            1       0
          NaN       1

U =
    1.0e-316 *
       0.8289  0.8289
            0     NaN

In the current version, results are more accurate. For example, using A as above,

[L,U] = lu(A)

L =
            1       0
            0       1

U =
    1.0e-316 *
       0.8289  0.8289
            0       0 

This improved accuracy carries with it a performance loss for any operations that use lu or lu-based \ (backslash) for factorization of full matrices.

Improved Workspace browser performance with many variables

There is no longer a performance problem with more than 1000 variables open in the Workspace browser.

Modal dialog behavior improvements

Modal dialogs on Windows platforms have been improved in terms of common appearance and stability. In Release 12, MATLAB would sometimes lock up due to modal dialogs. In Release 13, this is fixed.

Serial port fixes

The lookfor function now automatically displays results

When you run lookfor, results will now automatically display in the Command Window. You no longer need to press Ctrl+C to display results. While lookfor is running, the status bar shows Busy.

Workspace browser allows renaming variables

You can now rename variables from within the Workspace Browser. Right-click a variable name, select Rename from the context menu, and edit the name.

Model-Based Calibration Toolbox

Click on a problem area listed below to read how it has been fixed.

3-D and 4-D design views
Breakpoint filling using "ShareCurvThenAve" algorithm
Converting variables to aliases
Cross Section tool now displays correct model error
Differences in the history of 1-D tables
Fitting and pruning RBF models
Importing data from Excel into a Dataset
Local sweep notes kept during data augmentation
Optimal designs no longer allow incorrect number of stratified levels
Outlier sweeps appearing in the global outlier list
Previewing large Latin Hypercube designs now faster
Stratified Latin Hypercube designs
Viewing imported data in Datasets
You can now delete designs without crashing the Model Browser

3-D and 4-D design views

The 3-D and 4-D design views will now correctly display all of the points in a design. Previously, for some factor ranges points at the edges of the graph, limits were not displayed.

Breakpoint filling using "ShareCurvThenAve" algorithm

Breakpoint filling using "ShareCurvThenAve" now works correctly in all cases and is significantly faster than in the previous version.

Converting variables to aliases

You can now convert all Variable Dictionary items into an alias of another Variable Dictionary item. Previously, this would cause an error in some circumstances where the items were being used elsewhere in the Cage project.

Cross Section tool now displays correct model error

The Cross Section view of the Model Selection window now displays the correct model error while the input factor lines are being dragged. Previously, the error shown while dragging the line was different from that shown when the mouse button was released.

Differences in the history of 1-D tables

1-D tables in Cage now correctly show the difference between two versions in the history.

Fitting and pruning RBF models

Re-fitting an RBF model after pruning now uses the correct value for log10 (GCV).

Importing data from Excel into a Dataset

You can now import large amounts of data from Excel into a Dataset. Previously, attempting to do this caused an error to occur.

Local sweep notes kept during data augmentation

When you add new data to a testplan that already has models, any sweep notes which have been made are now saved when the models are re-fitted.

Optimal designs no longer allow incorrect number of stratified levels

Optimal designs with stratified candidate sets will now correctly fail if there are not enough stratified levels to support the model. Previously, small numerical errors allowed the optimisation to proceed, but poor conditioning meant that the optimal value oscillated up and down.

Outlier sweeps appearing in the global outlier list

Previously, if a local sweep was removed from fitting at the local level, the global response features only showed the removed sweep in their list of removed points if one or more outliers was selected and removed at the global level. All removed points are now shown at the global response feature level all of the time.

Previewing large Latin Hypercube designs now faster

You can now create large Latin Hypercube designs from the Classical Design Browser without MATLAB appearing to hang. Previously a full set of search iterations was erroneously done before the expected waitbar appeared and the search commenced.

Stratified Latin Hypercube designs

Stratified Latin Hypercube designs now choose their stratified levels so they split the stratified dimension into exactly equal sections. Previously, the levels were "snapped" to the nearest non-stratified level, which depends on the total number of points in the design. This meant that some levels were shifted down slightly and others up.

Viewing imported data in Datasets

You can now view Datasets that consist entirely of imported data. Previously, viewing these datasets caused Cage to crash.

You can now delete designs without crashing the Model Browser

You can now delete designs from anywhere in the Design Editor tree without causing errors. Previously, if your best design was at the end of the design tree and you deleted a design, you received an error when you closed the Design Editor.

Optimization Toolbox

Ill-posed or ill-conditioned problems in fmincon

The function fmincon would in some small number of cases hang when the problem was ill-posed or ill-conditioned. In these cases, fmincon no longer hangs.

Signal Processing Toolbox

Click on a problem area listed below to read how it has been fixed.

aryule order limit increased
cremez example fixed
Frequency inputs for cheb1ord, cheb2ord, ellipord
Pole/Zero plot root multiplicity
Scaling of magnitude response in magnitude and phase plot
SPTool Filter Viewer Print Preview

aryule order limit increased

The model order in the aryule function is no longer limited to half the input signal length. The order now can be up to the signal length.

cremez example fixed

The second example on the cremez reference page has been updated and now works correctly.

Frequency inputs for cheb1ord, cheb2ord, ellipord

For the digital bandstop case, the frequency values returned from the cheb1ord, cheb2ord, and ellipord functions are no longer changed from the input frequency values.

Pole/Zero plot root multiplicity

The pole/zero plot in FDATool and FVTool now can display multiple roots at a single plot point.

Scaling of magnitude response in magnitude and phase plot

The scaling of the magnitude response portion of the Magnitude and Phase Analysis plot in both FDATool and FVTool was incorrect for some filters. It now is scaled correctly.

SPTool Filter Viewer Print Preview

Print Preview, when no markers are displayed in the SPTool Filter Viewer, now works correctly.

Simulink

Click on a problem area listed below to read how it has been fixed.

Block parameter defaults now stored in mdl file
Breaking disabled library links from the command line
Bus Selector adapts to bus structure changes
Changing Configurable Subsystem selection crashed MATLAB
Creating Simulink data object classes in the MATLAB work directory
Dot Product block now works in loops
Drag-selecting blocks froze UNIX
Grouping blocks caused divide-by-zero error
Improved detection of evenly spaced breakpoints in PreLook-Up Index Search and Look-Up Table n-D blocks
Keyboard panning capabilities added to Simulink diagram editor
MATLAB and Simulink lockup after ESC during drag operation
Multirate models caused Simulink to hang
PreLook-Up Index Search, Look-Up Table n-D (Flat interpolation) blocks now return top of table
Propagating library changes created recursive links
Pulse generator computed sample time
Scope Block will not crash when "Save To Workspace" variable name is longer than 31 characters
SegV when adding/deleting Simulink blocks with Model Browser open on Unix
Selecting Tools->Coverage Settings when all Simulink licenses are checked out
Self-modifying masked library blocks had missing connections
Shift+drag disconnected a block inside a locked reference block
Simulink debugger did not recognize CurrentBlock parameter

Block parameter defaults now stored in mdl file

The mdl file now has a new section, "BlockParameterDefaults." The default values for the parameters used by the block types present in the model are written into this section. Then, an individual block instance's parameter values are written into the mdl file only if they differ from the default. This technique reduces the size of the mdl file, as well as reducing the file load time. A block diagram parameter, SaveDefaultBlockParams, exists to control whether or not the parameter defaults are saved to the file. By default it is set to true.

Breaking disabled library links from the command line

Breaking disabled library links from the command-line now works.

Bus Selector adapts to bus structure changes

In previous releases, adding signals to a bus or otherwise changing its structure required that you update any Bus Selector blocks that select signals from the bus. In the current release, you need to update the Bus Selector only if it selects signals that no longer exist or no longer have unique names.

Changing Configurable Subsystem selection crashed MATLAB

The Configurable Subsystem has been made faster and more robust when changing block choices. This is especially noticeable for large subsystems.

Creating Simulink data object classes in the MATLAB work directory

Previous releases of Simulink prevented you from creating Simulink data object classes in the MATLAB directory or any of its subdirectories. The current release allows you to create classes in the work subdirectory of the MATLAB root directory.

Dot Product block now works in loops

In Release 12.1, a Dot Product block in a loop cannot determine its port dimension and hence causes a simulation error. Now the block assigns a default dimension setting to the port, thereby avoiding the simulation error.

Drag-selecting blocks froze UNIX

Releasing the left mouse button over the Simulink menu bar when drag- selecting multiple blocks caused UNIX to lock up. This has been fixed.

Grouping blocks caused divide-by-zero error

Grouping blocks in Simulink into a subsystem caused a divide-by-zero error if the blocks were too close to the top or left edge of the model. This has been fixed.

Improved detection of evenly spaced breakpoints in PreLook-Up Index Search and Look-Up Table n-D blocks

The option for using a fast index search algorithm that relies on evenly spaced breakpoints for look-up tables was enhanced to better detect evenly spaced breakpoints within a tolerance of value*eps. Note that breakpoint expressions such as [-5:0.1:5] may still need to be written as 0.1*[-50:50] to generate a dataset that is evenly spaced within the required tolerance. The linear and binary search options will of course still work on any strictly increasing breakpoint data set (not just evenly spaced ones).

Keyboard panning capabilities added to Simulink diagram editor

You can now scroll Simulink diagrams around using the keyboard by pressing the Ctrl key in conjunction with any of the arrow keys. This is sometimes more convenient than manipulating the scroll bars with the mouse.

MATLAB and Simulink lockup after ESC during drag operation

In previous releases, pressing the Esc key while dragging a block or performing other types of drag operations caused MATLAB and Simulink to become unresponsive. In the current release, pressing the Esc key will abort the drag operation.

Multirate models caused Simulink to hang

For multirate models that are simulated to very large times, Simulink would eventually miss a sample hit for one of the rates. This would cause Simulink to hang. This has now been fixed and Simulink no longer hangs.

PreLook-Up Index Search, Look-Up Table n-D (Flat interpolation) blocks now return top of table

The behavior of the PreLook-Up Index Search block (index only mode) and the Look-Up Table n-D block (in flat interpolation mode) were changed to return the last index in the table when the input value is at or above the last breakpoint value as this is more useful than the previous behavior. For the Look-Up Table n-D block, this is done on an individual dimension basis. In previous versions (Simulink 4.0 and 4.1), the index search would deliberately return the next to last index and the n-D flat look-up would deliberately return the next to last table value even when the input value was at or above the last breakpoint.

Propagating library changes created recursive links

If changes are made to a linked block, propagating such changes to the library via the Link options menu now does not result in recursive links.

Pulse generator computed sample time

The pulse generator block would somtimes report that the computed sample time is not an integer multiple fo the fixed step size when, in fact, it was. This has been fixed.

Scope Block will not crash when "Save To Workspace" variable name is longer than 31 characters

Scope blocks with "Save To Workspace" variable names longer than the maximum MATLAB variable length (currently 31 characters) used to crash Simulink in unpredictable ways during simulation. Such variable names will no longer crash Simulink, though they will generate an error.

SegV when adding/deleting Simulink blocks with Model Browser open on Unix

On Unix platforms, a segmentation violation would occur if you added or deleted blocks in a Simulink model while the Model Browser was open. This has been fixed.

Selecting Tools->Coverage Settings when all Simulink licenses are checked out

The "Undefined variable names" error is no longer displayed when selecting Menu->Tools->Coverage Settings without an available Simulink license.

Self-modifying masked library blocks had missing connections

Library subsystems containing self-modifying masked blocks no longer have to be marked as MaskSelfModifiable for the linked blocks to be connected properly.

Shift+drag disconnected a block inside a locked reference block

In previous releases, holding down the Shift key and dragging a block inside a reference block (i.e., a library link) disconnects the block's signal lines and brings up a dialog box asking if you would like to disable the link. In the current release, Simulink does not disconnect the lines.

Simulink debugger did not recognize CurrentBlock parameter

In the previous release, you could not use get_param or set_param to set or get the value of the CurrentBlock parameter in the command-line debugger until you selected a block. The Simulink command-line debugger now allows you to set and get the value of this parameter without having to first select a block with the mouse.

Simulink Accelerator

Click on a problem area listed below to read how it has been fixed.

Non-inlined S-functions that accept non-double parameters will now work with the accelerator
Simulink Accelerator has correct minor step guard for enable, if, case
Simulink Accelerator now functions without an RTW license
Simulink Accelerator supports gcc compiler on UNIX

Non-inlined S-functions that accept non-double parameters will now work with the accelerator

In previous releases, if a non-inlined S-function used non-double parameter then the model would error out while trying to generate accelerator code. This restriction has been relaxed.

Simulink Accelerator has correct minor step guard for enable, if, case

Under certain circumstances with the Simulink Accelerator, the generated code of models containing enable, if and case subsystems could be activiated during minor time steps, causing incorrect outputs. This has been fixed.

Simulink Accelerator now functions without an RTW license

The Simulink Accelerator no longer requires a Real-Time Workshop license to function properly.

Simulink Accelerator supports gcc compiler on UNIX

The Simulink Accelerator now supports use of the gcc compiler on UNIX systems.

Spline Toolbox

Click on a problem area listed below to read how it has been fixed.

pprfn failed when no breaks need be inserted
Data edits in splinetool now tracked properly
Errors in spcol for various unusual inputs corrected

pprfn failed when no breaks need be inserted

pprfn now properly returns the function unchanged in case all the additional breaks are already breaks for the function.

Data edits in splinetool now tracked properly

Each spline fit now remembers the data to which it was fit. If, at some point, you make a previously constructed spline fit the current one, then also the data currently showing get changed to the data to which that spline was fit.

Errors in spcol for various unusual inputs corrected

spcol now provides a correct sparse version of its output even for knot sequences with unusual end knot multiplicities, and when some sites lie to the right of the last knot while some site appears more than once. None of these cases is likely to occur in ordinary spline work since, in all of them, the resulting matrix is not invertible.

Stateflow

Click on a problem area listed below to read how it has been fixed.

Code generation for RTW target failed for array data initialized from workspace
Generated code for RTW target did not include custom code
Hierarchical printing for closed charts caused transition and printout errors
Infinite flow graph loops in Stateflow did not stop during simulation
Mismatched dimensions in assignments not flagged by parser
Model file names in Stateflow were limited to 25 characters
Pointer and address operator use in generated code caused compile errors
Search and Replace errored out with LaTex strings in annotations
Smart transitions in resized grouped state were graphically messy
Transition actions were handled incorrectly for a confluence of transitions
Transition source for event broadcast was highlighted for the rest of simulation

Code generation for RTW target failed for array data initialized from workspace

Code generation for an RTW target no longer fails when the chart includes output array data initialized from the workspace. (Occurred in Versions 3.0 through 4.1.1.)

Generated code for RTW target did not include custom code

Code generated for an RTW target now can includes any custom code entered by a user. (Occurred in Versions 4.1 through 4.1.1.)

Hierarchical printing for closed charts caused transition and printout errors

Hierachical Printing invoked from a Simulink window when the charts were closed no longer causes transition label positions to change and no longer causes incorrect printouts. (Occurred in Version 4.0 through 4.1)

Infinite flow graph loops in Stateflow did not stop during simulation

In models containing an infinite flow graph loop, you can now stop simulation by using Ctrl-C or the Stop Simulation button in the diagram editor and debug window.

Mismatched dimensions in assignments not flagged by parser

The Stateflow parser did not flag mismatched dimensions or array lengths in vectorized assignments such as x = y, where x and y are vector data with different dimensions and/or lengths. This no longer causes crashes during runtime. (Occurred in Versions 2.0 through 4.1.)

Model file names in Stateflow were limited to 25 characters

Models containing Stateflow charts must have file names limited to 25 characters or less. When you try to save a model with more characters, an error results. If you try to load a model with more than 25 characters in its file name, a warning results telling you to reduce the number of characters in the file name to 25 or less.

Pointer and address operator use in generated code caused compile errors

Certain uses of the pointer and address operators ('->' and '&', respectively) in state and transition actions used to cause uncompilable generated code. (Occurred in Versions 3.0 through 4.1.1). This has been fixed.

Search and Replace errored out with LaTex strings in annotations

The Stateflow Search and Replace Tool no longer errors out in the presence of LaTeX format strings in Stateflow annotations. (Occurred in Versions 4.0.2 through 4.1.)

Smart transitions in resized grouped state were graphically messy

When a grouped state containing "smart" transitions was resized, the transitions in the newly resized state are now displayed properly. (Occurred in Version 4.1)

Transition actions were handled incorrectly for a confluence of transitions

Transition actions are now handled correctly for a confluence of transitions into a single destination such as the junction shown below:

Transition source for event broadcast was highlighted for the rest of simulation

During simulation an early return from an event broadcast from a transition no longer leaves that transition highlighted for the rest of the simulation. (Occurred in Versions 3.0 through 4.1.)

Stateflow Coder

Click on a problem area listed below to read how it has been fixed.

Charts containing unstructured flow graphs caused compilation errors during Real-Time Workshop builds
Missing return statements in some graphical functions
Optimization of simple "if" conditional statements caused incorrect code
Optimization of state exit functions caused incorrect code to be generated
Passing chart input data to graphical functions caused code generation failure for RTW targets
Using min/max macros in Stateflow charts caused compilation failures during RTW build

Charts containing unstructured flow graphs caused compilation errors during Real-Time Workshop builds

Charts containing unstructured flow graphs no longer cause compilation errors during Real-Time Workshop builds.

Missing return statements in some graphical functions

All graphical functions with a return value and unusual flow graph topology now include a final return statement in the generated code.

Optimization of simple "if" conditional statements caused incorrect code

Optimization of simple "if" conditional statements no longer causes incorrect code to be generated. (Occurred in Version 4.2)

Optimization of state exit functions caused incorrect code to be generated

Optimization of state exit functions no olonger causes incorrect code to be generated. (Occurred in Version 4.2)

Passing chart input data to graphical functions caused code generation failure for RTW targets

Passing chart input data to graphical functions no longer causes code generation failures for Real-Time Workshop targets.

Using min/max macros in Stateflow charts caused compilation failures during RTW build

Using min/max macros in Stateflow charts caused compilation failures during RTW builds of ert/grt embedded targets. This has been fixed.

Statistics Toolbox

Click on a problem area listed below to read how it has been fixed.

cluster function usable with larger problems
dendrogram graph corrected for plotting a subset of nodes
pdist more efficient for large data sets
ranksum uses a continuity correction
Corrected calculation of covratio statistic by regstats function
Linear and quadratic discriminant analysis added to classify
Negative binomial (nbin*) functions no longer require an integer R value

cluster function usable with larger problems

The cluster function is no longer recursive, so it no longer encounters a recursion limit when it is applied to a large data set. Consequently, cluster now succeeds with larger data sets than in the past.

dendrogram graph corrected for plotting a subset of nodes

In a plot of a subset of the nodes in a cluster tree, the dendrogram function now adjusts the Y axis limits to scale the tree properly, and it shows the correct distance values. Before Version 4.0 (Release 13), it was subtracting an offset to position the minimum distance value near zero, and therefore it was not possible to read the correct distance values from the Y axis of the resulting plot.

pdist more efficient for large data sets

The pdist function now makes more efficient use of memory, so it can be used on larger problems than in previous releases.

ranksum uses a continuity correction

The ranksum function uses an exact calculation for small sample sizes, and a normal approximation for larger sample sizes. Starting in Version 4.0 (Release 13), the normal approximation now includes a continuity correction.

Corrected calculation of covratio statistic by regstats function

In Version 3.0 and earlier of the Statistics Toolbox, the covratio statistic was calculated incorrectly. The calculation was fixed in Version 3.1. This statistic measures the ratio of the generalized variance of the coefficient estimates without a given row, to the generalized variance using all the data.

Linear and quadratic discriminant analysis added to classify

The algorithm that was previously implemented in classify used the Mahalanobis distance between sample points and training groups, with stratified estimates of covariance. The new implementation adds the standard algorithms for linear (default) and quadratic discriminant analysis. Use the type 'mahalanobis' in the new version to duplicate the behavior of the previous version.

Negative binomial (nbin*) functions no longer require an integer R value

Consistent with a more general interpretation of the negative binomial, these functions now accept any positive value, including nonintegers, for the size parameter R: nbincdf, nbininv, nbinpdf, nbinrnd, nbinstats.

Wavelet Toolbox

Click on a problem area listed below to read how it has been fixed.

cmorwavf function inputs
Different results for std2 function in the Wavelet and Image Processing Toolboxes
Loading wptree object from a MAT-file
Loading complex data into Continuous Wavlet 1-D
Using wpdec function with a user-defined function

cmorwavf function inputs

The two last input arguments are no longer reversed in the cmorwavf function.

Different results for std2 function in the Wavelet and Image Processing Toolboxes

You no longer get slightly different results from the std (compute standard deviation of matrix elements) function in the Image Processing Toolbox and the Wavelet Toolbox.

Loading wptree object from a MAT-file

wptree has been updated so that a wptree object can be loaded from a MAT-file.

Loading complex data into Continuous Wavlet 1-D

An error message stating that the data must be real is displayed when you try to load complex data into the Continuous Wavlet 1-D.

Using wpdec function with a user-defined function

Using wpdec with a user-defined function no longer produces errors that were caused by wpdec's use of wentropy.

xPC Target

Polling mode with embedded option

Previously, when you created a Stand-alone application, polling mode did not start. Now, it does.