Borrar filtros
Borrar filtros

error using horzcat function

8 visualizaciones (últimos 30 días)
rida
rida el 14 de Jun. de 2023
Comentada: rida el 14 de Jun. de 2023
Very simple code of adding two matrices horizontally retyrns an error using horzcat, dimensions of arrays being concatenated are not consistent. the error is on line (theta = [theta(:,1:6),zeros(length(theta),1)];).
the excel file has a matrix of 4x6, which i check with size theta even.
the code is:
clear all
clc
% Input:
tmp = importdata ('exp.xlsx');
theta = tmp.data;
theta = [theta(:,1:6),zeros(length(theta),1)];
% Calcu
theta (:,7) = theta (:,2).*theta(:,3);
%output
file_name = 'total.txt';
fid = fopen(file_name,'w');
fprintf(fid,'This file is written by matlab code.\n\n');
fprintf(fid,'This code will calculate the total.\n\n');
for i = 1:length(theta)
fprintf(fid,'The total of %d with age %f and exp %f is %f.\n',theta(i,1),theta(i,2),theta(i,3),theta(i,4));
end
fprintf(fid,'\nENDFILE');
fclose (fid);

Respuesta aceptada

VBBV
VBBV el 14 de Jun. de 2023
Editada: VBBV el 14 de Jun. de 2023
theta = [theta(:,1:6),zeros(size(theta,1),1)];
  4 comentarios
Steven Lord
Steven Lord el 14 de Jun. de 2023
The length function on a non-empty array returns the size in the longest dimension of your array. That's not necessarily the number of rows.
A = ones(3, 6);
length(A)
ans = 6
Calling size with 1 as the dimension input will give you the number of rows in the array.
size(A, 1)
ans = 3
rida
rida el 14 de Jun. de 2023
thanks, this was very helpful. much thanks

Iniciar sesión para comentar.

Más respuestas (1)

Satwik
Satwik el 14 de Jun. de 2023
You can make the following change if your goal is to concatenate.
tmp = zeros(4,6);
theta = tmp;
theta = [theta(:,1:6),zeros(size(theta,1),1)]
theta = 4×7
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Categorías

Más información sobre Creating and Concatenating Matrices en Help Center y File Exchange.

Etiquetas

Productos


Versión

R2019a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by