Answer the given question with a proper explanation and step-by-step solution.  Solve the assembly question regarding registers written in C code

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Topic Video
Question

Answer the given question with a proper explanation and step-by-step solution.

 Solve the assembly question regarding registers written in C code 

The following is a segment of C code for matrix multiplication C=C+A*B. How many times each matrix element needs
to be accessed/used? How many times each matrix element needs to be loaded-from and stored-to memory?
for (i=0; i<n; i++)
for(j=0; j<n; j++)
for (k=0; k<n; k++)
C[i*n+j]+=A[i*n+k]*B[k*n+j];
The following improved code reduces the number of memory load and stores for matrix C by using a register to
store C[i*n+j]. How many times each matrix element needs to be loaded-from and stored-to memory? Report the
performance of both the original version and this improved version code for matrices of size 1000, 1500, 2000, 2500.
for (i=0; i<n; i++)
}
for (j=0; j<n; j++){
register double t=C[i*n+j];
for (k=0; k<n; k++)
t+=A[i*n+k]*B[k*n+j];
C[i*n+j]=t;
More aggressive optimization can be done by reducing the memory load and store for matrix A, B, and C. Implement
the idea discussed in the last slides of the class lecture, verify the correctness of your implementation by checking
the maximum error in the result matrix C, and compare the performance with the previous two versions.
Transcribed Image Text:The following is a segment of C code for matrix multiplication C=C+A*B. How many times each matrix element needs to be accessed/used? How many times each matrix element needs to be loaded-from and stored-to memory? for (i=0; i<n; i++) for(j=0; j<n; j++) for (k=0; k<n; k++) C[i*n+j]+=A[i*n+k]*B[k*n+j]; The following improved code reduces the number of memory load and stores for matrix C by using a register to store C[i*n+j]. How many times each matrix element needs to be loaded-from and stored-to memory? Report the performance of both the original version and this improved version code for matrices of size 1000, 1500, 2000, 2500. for (i=0; i<n; i++) } for (j=0; j<n; j++){ register double t=C[i*n+j]; for (k=0; k<n; k++) t+=A[i*n+k]*B[k*n+j]; C[i*n+j]=t; More aggressive optimization can be done by reducing the memory load and store for matrix A, B, and C. Implement the idea discussed in the last slides of the class lecture, verify the correctness of your implementation by checking the maximum error in the result matrix C, and compare the performance with the previous two versions.
Expert Solution
steps

Step by step

Solved in 4 steps

Blurred answer
Knowledge Booster
Instruction Format
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education