Results for

Check out how these charts were made with polar axes in the Graphics and App Building blog's latest article "Polar plots with patches and surface".

Nine new Image Processing courses plus one new learning path are now available as part of the Online Training Suite. These courses replace the content covered in the self-paced course Image Processing with MATLAB, which sunsets in 2026. 
New courses include:
- Work with Image Data Types
- Image Registration
- Edge, Circle, and Line Detection
- Manage and Process Multiple Images
The new learning path Image Segmentation and Analysis in MATLAB earns users the digital credential Image Segmentation in MATLAB and contains the following courses:
Apparently, the back end here is running 2025b, hovering over the Run button and the Executing In popup both show R2024a.
ver matlab
all(logical.empty)
Discuss!
I just noticed that MATLAB R2025b is available. I am a bit surprised, as I never got notification of the beta test for it.
This topic is for highlights and experiences with R2025b.
For some time now, this has been bugging me - so I thought to gather some more feedback/information/opinions on this.
What would you classify Recursion? As a loop or as a vectorized section of code?
For context, this query occured to me while creating Cody problems involving strict (so to speak) vectorization - (Everyone is more than welcome to check my recent Cody questions). 
To make problems interesting and/or difficult, I (and other posters) ban functions and functionalities - such as for loops, while loops, if-else statements, arrayfun() and the rest of the fun() family functions. However, some of the solutions including the reference solution I came up with for my latest problem, contained recursion.
I am rather divided on how to categorize it. What do you think?
Have you ever been enrolled in a course that uses an LMS and there is an assignment that invovles posting a question to, or answering a question in, a discussion group?  This discussion group is meant to simulate that experience.  
The functionality would allow report generation straight from live scripts that could be shared without exposing the code. This could be useful for cases where the recipient of the report only cares about the results and not the code details, or when the methodology is part of a company know how, e.g. Engineering services companies.
In order for it to be practical for use it would also require that variable values could be inserted into the text blocks, e.g. #var_name# would insert the value of the variable "var_name" and possibly selecting which code blocks to be hidden.
“Hello, I am Subha & I’m part of the organizing/mentoring team for NASA Space Apps Challenge Virudhunagar 2025 🚀. We’re looking for collaborators/mentors with ML and MATLAB expertise to help our student teams bring their space solutions to life. Would you be open to guiding us, even briefly? Your support could impact students tackling real NASA challenges. 🌍✨”
Since R2024b, a Levenberg–Marquardt solver (TrainingOptionsLM) was introduced. The built‑in function trainnet now accepts training options via the trainingOptions function (https://www.mathworks.com/help/deeplearning/ref/trainingoptions.html#bu59f0q-2) and supports the LM algorithm. I have been curious how to use it in deep learning, and the official documentation has not provided a concrete usage example so far. Below I give a simple example to illustrate how to use this LM algorithm to optimize a small number of learnable parameters.
For example, consider the nonlinear function:
y_hat = @(a,t) a(1)*(t/100) + a(2)*(t/100).^2 + a(3)*(t/100).^3 + a(4)*(t/100).^4;
It represents a curve. Given 100 matching points (t → y_hat), we want to use least squares to estimate the four parameters a1–a4.
t = (1:100)';
y_hat = @(a,t)a(1)*(t/100) + a(2)*(t/100).^2 + a(3)*(t/100).^3 + a(4)*(t/100).^4;
x_true = [ 20 ;  10 ;  1 ;  50 ];
y_true = y_hat(x_true,t);
plot(t,y_true,'o-')
- Using the traditional lsqcurvefit-wrapped "Levenberg–Marquardt" algorithm:
x_guess = [  5 ;  2 ;  0.2 ;  -10 ]; 
options = optimoptions("lsqcurvefit",Algorithm="levenberg-marquardt",MaxFunctionEvaluations=800);
[x,resnorm,residual,exitflag] = lsqcurvefit(y_hat,x_guess,t,y_true,-50*ones(4,1),60*ones(4,1),options);
x,resnorm,exitflag
- Using the deep-learning-wrapped "Levenberg–Marquardt" algorithm:
options = trainingOptions("lm", ...
    InitialDampingFactor=0.002, ...
    MaxDampingFactor=1e9, ...
    DampingIncreaseFactor=12, ...
    DampingDecreaseFactor=0.2,...
    GradientTolerance=1e-6, ...
    StepTolerance=1e-6,...
    Plots="training-progress");
numFeatures = 1;
layers = [featureInputLayer(numFeatures,'Name','input')
    fitCurveLayer(Name='fitCurve')];
net = dlnetwork(layers);
XData = dlarray(t);
YData = dlarray(y_true);
netTrained = trainnet(XData,YData,net,"mse",options);
netTrained.Layers(2)
classdef fitCurveLayer < nnet.layer.Layer ...
        & nnet.layer.Acceleratable
    % Example custom SReLU layer.
    properties (Learnable)
    % Layer learnable parameters
        a1
        a2
        a3
        a4
    end
    methods
        function layer = fitCurveLayer(args) 
            arguments
                args.Name = "lm_fit";
            end
            % Set layer name.
            layer.Name = args.Name;
            % Set layer description.
            layer.Description = "fit curve layer";
        end
        function layer = initialize(layer,~)
            % layer = initialize(layer,layout) initializes the layer
            % learnable parameters using the specified input layout.
            if isempty(layer.a1)
                layer.a1 = rand();
            end
            if isempty(layer.a2)
                layer.a2 = rand();
            end
            if isempty(layer.a3)
                layer.a3 = rand();
            end
            if isempty(layer.a4)
                layer.a4 = rand();
            end
        end
        function Y = predict(layer, X)
            % Y = predict(layer, X) forwards the input data X through the
            % layer and outputs the result Y.
            % Y = layer.a1.*exp(-X./layer.a2) + layer.a3.*X.*exp(-X./layer.a4);
            Y = layer.a1*(X/100) + layer.a2*(X/100).^2 + layer.a3*(X/100).^3 + layer.a4*(X/100).^4;
        end
    end
end
The network is very simple — only the fitCurveLayer defines the learnable parameters a1–a4. I observed that the output values are very close to those from lsqcurvefit.
For the www, uk, and in domains,a generative search answer is available for Help Center searches.  Please let us know if you get good or bad results for your searches.  Some have pointed out that it is not available in non-english domains.  You can switch your country setting to try it out.  You can also ask questions in different languages and ask for the response in a different language. I get better results when I ask more specific queries. How is it working for you?
I’d like to take a moment to highlight the great contributions of one of our community members, @Paul, who is fast approaching an impressive 5,000 reputation points!
Paul has built his reputation the best way possible - by generously sharing his knowledge and helping others. Over the last few years, he’s provided thoughtful and practical answers to hundreds of questions, making life a little easier for learners and experts alike.
Reputation points are more than just numbers here - they represent the trust and appreciation of the community. Paul’s upcoming milestone is a testament to his consistency, expertise, and willingness to support others.
Please join me in recognizing Paul's contributions and impact on the MATLAB Central community.
Modern engineering requires both robust hardware and powerful simulation tools. MATLAB and Simulink are widely used for data analysis, control design, and embedded system development. At the same time, Kasuo offers a wide range of components—from sensors and connectors to circuit protection devices—that engineers rely on to build real-world systems.
By combining these tools, developers can bridge the gap between simulation and implementation, ensuring their designs are reliable and ready for deployment.
Example Use Case: Sensor Data Acquisition and Processing
- Kasuo Hardware Setup
- Select a Kasuo sensor (e.g., temperature, microphone, or motion sensor).
- Connect it to a DAQ or microcontroller board for data collection.
- Data Acquisition in MATLAB
- Use MATLAB’s Data Acquisition Toolbox to stream sensor data directly.
- Example snippet:
s = daq("ni");
addinput(s, 
"Dev1", "ai0", "Voltage");
data = read(s, seconds(
5), "OutputFormat", "Matrix");
plot(data);
- Signal Processing with Simulink
- Build a Simulink model to filter noise, detect anomalies, or design control logic.
- Simulink enables real-time visualization and iterative tuning.
- Validation & Protection Simulation
- Add Kasuo’s circuit protection components (e.g., TVS diodes, surge suppressors) in the physical design.
- Use Simulink to simulate stress conditions, validating system robustness before hardware testing.
Benefits of the Workflow
- Faster prototyping with MATLAB & Simulink.
- Greater reliability by incorporating Kasuo protection devices.
- Seamless transition from model to hardware implementation.
Conclusion
Kasuo’s electronic components provide the hardware foundation for many embedded and signal processing applications. When combined with MATLAB and Simulink, engineers can design, simulate, and validate systems more efficiently—reducing risks and development time.
With AI agents dev coding on other languages has become so easy.
Im waiting for matlab to build something like warp but for matlab.
I know they have the current ai but with all respect it's rubbish compared to vibe coding tools in others sectors.
Matlab leads AI so it really should be leading this space.
Function Syntax Design Conundrum
As a MATLAB enthusiast, I particularly enjoy Steve Eddins' blog and the cool things he explores. MATLAB's new argument blocks are great, but there's one frustrating limitation that Steve outlined beautifully in his blog post "Function Syntax Design Conundrum": cases where an argument should accept both enumerated values AND other data types.
Steve points out this could be done using the input parser, but I prefer having tab completions and I'm not a fan of maintaining function signature JSON files for all my functions.
Personal Context on Enumerations
To be clear: I honestly don't like enumerations in any way, shape, or form. One reason is how awkward they are. I've long suspected they're simply predefined constructor calls with a set argument, and I think that's all but confirmed here. This explains why I've had to fight the enumeration system when trying to take arguments of many types and normalize them to enumerated members, or have numeric values displayed as enumerated members without being recast to the superclass every operation.
The Discovery
While playing around extensively with metadata for another project, I realized (and I'm entirely unsure why it took so long) that the properties of a metaclass object are just, in many cases, the attributes of the classdef. In this realization, I found a solution to Steve's and my problem.
To be clear: I'm not in love with this solution. I would much prefer a better approach for allowing variable sets of membership validation for arguments. But as it stands, we don't have that, so here's an interesting, if incredibly hacky, solution.
If you call struct() on a metaclass object to view its hidden properties, you'll notice that in addition to the public "Enumeration" property, there's a hidden "Enumerable" property. They're both logicals, which implies they're likely functionally distinct. I was curious about that distinction and hoped to find some functionality by intentionally manipulating these values - and I did, solving the exact problem Steve mentions.
The Problem Statement
We have a function with an argument that should allow "dual" input types: enumerated values (Steve's example uses days of the week, mine uses the "all" option available in various dimension-operating functions) AND integers. We want tab completion for the enumerated values while still accepting the numeric inputs.
A Solution for Tab-Completion Supported Arguments
Rather than spoil Steve's blog post, let me use my own example: implementing a none() function. The definition is simple enough tf = ~any(A, dim); but when we wrap this in another function, we lose the tab-completion that any() provides for the dim argument (which gives you "all"). There's no great way to implement this as a function author currently - at least, that's well documented.
So here's my solution:
%% Example Function Implementation
% This is a simple implementation of the DimensionArgument class for implementing dual type inputs that allow enumerated tab-completion.
function tf = none(A, dim)
    arguments(Input)
        A logical;
        dim DimensionArgument = DimensionArgument(A, true);
    end
    % Simple example (notice the use of uplus to unwrap the hidden property)
    tf = ~any(A, +dim);
end
I like this approach because the additional work required to implement it, once the enumeration class is initialized, is minimal. Here are examples of function calls, note that the behavior parallels that of the MATLAB native-style tab-completion:
%% Test Data
% Simple logical array for testing
A = randi([0, 1], [3, 5], "logical");
%% Example function calls
tf = none(A, "all");     % This is the tab-completion it's 1:1 with MATLABs behavior
tf = none(A, [1, 2]);    % We can still use valid arguments (validated in the constructor)
tf = none(A);            % Showcase of the constructors use as a default argument generator
How It Works
What makes this work is the previously mentioned Enumeration attribute. By setting Enumeration = false while still declaring an enumeration block in the classdef file, we get the suggested members as auto-complete suggestions. As I hinted at, the value of enumerations (if you don't subclass a builtin and define values with the someMember (1) syntax) are simply arguments to constructor calls.
We also get full control over the storage and handling of the class, which means we lose the implicit storage that enumerations normally provide and are responsible for doing so ourselves - but I much prefer this. We can implement internal validation logic to ensure values that aren't in the enumerated set still comply with our constraints, and store the input (whether the enumerated member or alternative type) in an internal property.
As seen in the example class below, this maintains a convenient interface for both the function caller and author the only particuarly verbose portion is the conversion methods... Which if your willing to double down on the uplus unwrapping context can be avoided. What I have personally done is overload the uplus function to return the input (or perform the identity property) this allowss for the uplus to be used universally to unwrap inputs and for those that cant, and dont have a uplus definition, the value itself is just returned:
classdef(Enumeration = false) DimensionArgument % < matlab.mixin.internal.MatrixDisplay
    %DimensionArgument Enumeration class to provide auto-complete on functions needing the dimension type seen in all()
    %      Enumerations are just macros to make constructor calls with a known set of arguments. Declaring the 'all'
    %      enumeration member means this class can be set as the type for an input and the auto-completion for the given
    %      argument will show the enumeration members, allowing tab-completion. Declaring the Enumeration attribute of
    %      the class as false gives us control over the constructor and internal implementation. As such we can use it 
    %      to validate the numeric inputs, in the event the 'all' option was not used, and return an object that will 
    %      then work in place of valid dimension argument options.
    %% Enumeration members
    %      These are the auto-complete options you'd like to make available for the function signature for a given
    %      argument.
    enumeration(Description="Enumerated value for the dimension argument.")
        all
    end
    %% Properties
    %      The internal property allows the constructor's input to be stored; this ensures that the value is store and 
    %      that the output of the constructor has the class type so that the validation passes.
    %      (Constructors must return the an object of the class they're a constructor for)
    properties(Hidden, Description="Storage of the constructor input for later use.")
        Data = [];
    end
    %% Constructor method
    %      By the magic of declaring (Enumeration = false) in our class def arguments we get full control over the
    %      constructor implementation.
    %
    %      The second argument in this specific instance is to enable the argument's default value to be set in the
    %      arguments block itself as opposed to doing so in the function body... I like this better but if you didn't
    %      you could just as easily keep the constructor simple.
    methods
        function obj = DimensionArgument(A, Adim)
            %DimensionArgument Initialize the dimension argument.
            arguments
                % This will be the enumeration member name from auto-completed entries, or the raw user input if not
                % used.
                A = [];
                % A flag that indicates to create the value using different logic, in this case the first non-singleton
                % dimension, because this matches the behavior of functions like, all(), sum() prod(), etc.
                Adim (1, 1) logical = false;
            end
            if(Adim)
                % Allows default initialization from an input to match the aforemention function's behavior
                obj.Data = firstNonscalarDim(A);
            else
                % As a convenience for this style of implementation we can validate the input to ensure that since we're
                % suppose to be an enumeration, the input is valid
                DimensionArgument.mustBeValidMember(A);
                % Store the input in a hidden property since declaring ~Enumeration means we are responsible for storing
                % it.
                obj.Data = A;
            end
        end
    end
    %% Conversion methods
    %      Applies conversion to the data property so that implicit casting of functions works. Unfortunately most of
    %      the MathWorks defined functions use a different system than that employed by the arguments block, which
    %      defers to the class defined converter methods... Which is why uplus (+obj) has been defined to unwrap the
    %      data for ease of use.
    methods
        function obj = uplus(obj)
            obj = obj.Data;
        end
        function str = char(obj)
            str = char(obj.Data);
        end
        function str = cellstr(obj)
            str = cellstr(obj.Data);
        end
        function str = string(obj)
            str = string(obj.Data);
        end
        function A = double(obj)
            A = double(obj.Data);
        end
        function A = int8(obj)
            A = int8(obj.Data);
        end
        function A = int16(obj)
            A = int16(obj.Data);
        end
        function A = int32(obj)
            A = int32(obj.Data);
        end
        function A = int64(obj)
            A = int64(obj.Data);
        end
    end
    %% Validation methods
    %      These utility methods are for input validation
    methods(Static, Access = private)
        function tf = isValidMember(obj)
            %isValidMember Checks that the input is a valid dimension argument.
            tf = (istext(obj) && all(obj == "all", "all")) || (isnumeric(obj) && all(isint(obj) & obj > 0, "all"));
        end
        function mustBeValidMember(obj)
            %mustBeValidMember Validates that the input is a valid dimension argument for the dim/dimVec arguments.
            if(~DimensionArgument.isValidMember(obj))
                exception("JB:DimensionArgument:InvalidInput", "Input must be an integer value or the term 'all'.")
            end
        end
    end
    %% Convenient data display passthrough
    methods
        function disp(obj, name)
            arguments
                obj DimensionArgument
                name string {mustBeScalarOrEmpty} = [];
            end
            % Dispatch internal data's display implementation
            display(obj.Data, char(name));
        end
    end
end
In the event you'd actually play with theres here are the function definitions for some of the utility functions I used in them, including my exception would be a pain so i wont, these cases wont use it any...
% Far from my definition isint() but is consistent with mustBeInteger() for real numbers but will suffice for the example
function tf = isint(A)
    arguments
        A {mustBeNumeric(A)};
    end
    tf = floor(A) == A
end
% Sort of the same but its fine
function dim = firstNonscalarDim(A)
    arguments
        A 
    end
    dim = [find(size(A) > 1, 1), 0];
    dim(1) = dim(1);
end
Hello MATLAB Central, this is my first article.
My name is Yann. And I love MATLAB.
I also love HTTP (i know, weird fetish)
So i started a conversation with ChatGPT about it:
gitclone('https://github.com/yanndebray/HTTP-with-MATLAB');
cd('HTTP-with-MATLAB')
http_with_MATLAB
I'm not sure that this platform is intended to clone repos from github, but i figured I'd paste this shortcut in case you want to try out my live script http_with_MATLAB.m
A lot of what i program lately relies on external web services (either for fetching data, or calling LLMs).
So I wrote a small tutorial of the 7 or so things I feel like I need to remember when making HTTP requests in MATLAB.
Let me know what you think
Hello MATLAB Central community,
My name is Yann. And I love MATLAB. I also love Python ... 🐍 (I know, not the place for that).
I recently decided to go down the rabbit hole of AI. So I started benchmarking deep learning frameworks on basic examples. Here is a recording of my experiment: 
Happy to engage in the debate. What do you think?
a = [ 1 2 3 ]
a =
     1     2     3
b = [ 3; 5; 8]
b =
     3
     5
     8
x = a + b
x =
     4     5     6
     6     7     8
     9    10    11
Hi,
I have some problem, I want to upload my data that sample rate at 500HZ, every sevral seconds.
My data include 12 bytes, and it measure 500HZ, for example for 15 seconds I coolect 15*500*12 = 84KB.
Can I upload this data to ThingSpeak? It is possible to use with Free acount (I am student and this is my project)
How can help me..
I can not understand why Plot Browser was taken away in latest Matlab... I use Plot Browser all of the time!  Having to find and click the particular line I want in a plot with a lot of lines is way less convenient than just selecting it in the Plot Browser.  Also, being able to quickly hide/show multiple lines at once with the plot browser was so helpful in a lot of cases.  Please bring Plot Browser back!!!!  Please reply with support for this if you feel the same as I do!

















