7503 Guia de Ejercicios Abacus v1.1
7503 Guia de Ejercicios Abacus v1.1
7503 Guia de Ejercicios Abacus v1.1
Abacus
Pgina 1 de 9
75.03 Organizacin del Computador A1. - Dada una mquina Abacus con las siguientes caractersticas: RPI = 12 bits AC = 16 bits
Operaciones disponibles: (Cdigos en hexadecimal) 0 Carga inmediata 7 Bifurca si (AC) < 0 1 Carga F Fin de Programa 2 Almacena 3 Suma 4 NOT (AC) 5 Bifurca si (AC) = 0 6 Bifurca si (AC) > 0 Punto de carga en la celda 500(16). Determinar el tamao de todos los componentes de la mquina y realizar un programa que resuelva lo siguiente: En las celdas 150(16) y 250(16) se encuentran almacenados dos nmeros X e Y. Efectuar X - Y almacenando el resultado en la celda 300(16). A2. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A1 realizar un programa que resuelva lo siguiente: En las celdas 150(16) y 250(16) se encuentran almacenados dos nmeros X e Y. Efectuar X * Y almacenando el resultado en la celda 300(16) A3. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A1 realizar un programa que resuelva lo siguiente: En las celdas 150(16) y 250(16) se encuentran almacenados dos nmeros X e Y. Efectuar X/Y almacenando el cociente en la celda 300(16) y el resto en la celda 301(16). A4. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A1 realizar un programa que resuelva lo siguiente: En la celda 150(16) se encuentra almacenado un nmero N.
N
Calcular
i 1
Pgina 2 de 9
75.03 Organizacin del Computador A5. - Dada una mquina Abacus con las siguientes caractersticas: RPI: 12 bits AC: 16 bits
Operaciones disponibles: (Cdigos en hexadecimal) 1 Bifurca si el (AC) < 0 2 Resta 3 Suma 4 Almacena 5 Carga En memoria, a partir de la celda 230(16) se encuentra el siguiente programa: 0001 5233 2233 4200 5200 3201 4200 5202 3230 4202 1234 Los contenidos de las celdas 201(16) y 202 respectivamente. El contenido del RPI es 231(16).
(16)
Se pide efectuar un seguimiento del programa detallando las microinstrucciones e indicar el estado final de todos los componentes (AC, RI, RPI, RM, RDM) y las celdas que se modifican. A6. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A1 realizar un programa que resuelva lo siguiente: En las celdas 100(16), 200(16) y 300(16) se encuentran almacenados tres nmeros X,Y,Z. Se pide ordenarlos en forma ascendente y almacenarlos en ese orden a partir de la direccin 700(16). A7. - Dada una mquina Abacus con las siguientes caractersticas: RPI = 12 bits AC = 16 bits
Operaciones disponibles: (Cdigos en hexadecimal) 0 Carga inmediata 1 Suma 2 Almacena 3 Fin de programa 4 Bifurca incondicionalmente Punto de carga en la celda 000 (16). En memoria, a partir de la celda 000(16) se encuentra el siguiente programa: 0005 1003 2003 6FFF 0FFF 1003 Se pide efectuar un seguimiento del programa detallando las microinstrucciones e indicar el estado final de todos los componentes (AC, RI, RPI, RM, RDM) y las celdas que se modifican.
Pgina 3 de 9
75.03 Organizacin del Computador A8. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A1 realizar un programa que resuelva lo siguiente: En la celda 150(16) se encuentra almacenado un nmero que representa la mxima longitud de un BPF c/signo en bits. Almacenar en la celda 300 (16) el menor nmero almacenable en esa cantidad de bits y el mayor nmero almacenable en la celda 301(16). A9. - Dada una mquina Abacus con las siguientes caractersticas: RPI = 12 bits AC = 16 bits
Operaciones disponibles: (Cdigos en hexadecimal) 1 Carga 2 Almacena 3 Suma 4 Bifurca si (AC) > 0 5 Bifurca incondicionalmente 6 Fin de programa En memoria, a partir de la celda 0FC (16) se encuentra el siguiente programa: 5100 8700 2101 6000 1071 3084 40FD 50FF Los contenidos de las celdas 071(16) y 084(16) son BF71(16) y 925A respectivamente.
(16)
Se pide efectuar un seguimiento del programa detallando las microinstrucciones e indicar el estado final de todos los componentes (AC, RI, RPI, RM, RDM) y las celdas que se modifican. A10. - Dada una mquina Abacus con las siguientes caractersticas: CO = 8 bits OP = 12bits
Operaciones disponibles (Cdigos en hexadecimal) A0 Carga inmediata A5 NOP A1 Carga A6 Bifurca si (AC) < 0 A2 Almacena A7 Bifurca incondicionalmente A3 Suma A8 Fin de Programa A4 Resta En memoria, a partir de la celda F31(16) se encuentra el siguiente programa: A0FFA A7F3B A6F34 A3F33 00001 A7F36 A4F37 A6F32 A7F31 A8F35 A1F3B A3F33 A2F3B
Determinar el tamao de todos los componentes de la mquina y efectuar un seguimiento del programa detallando las microinstrucciones e indicar el estado final de todos los componentes (AC, RI, RPI, RM, RDM) y las celdas que se modifican.
Gua de Ejercicios Abacus Versin 1.1 Pgina 4 de 9
75.03 Organizacin del Computador A11. - Dada una mquina Abacus con las siguientes caractersticas: RPI = 12 bits AC = 16 bits
Operaciones disponibles: (Cdigos en hexadecimal) 0 Carga inmediata 5 Bifurca si (AC) = 0 1 Carga 6 Bifurca si (AC) > 0 2 Almacena 7 Bifurca si (AC) < 0 3 Suma F Fin de Programa 4 NOT (AC) Punto de carga en la celda 105(16). Las celdas 200(16) y 201(16) contienen dos direcciones, se pide calcular la sumatoria de todas las celdas comprendidas entre las direcciones dadas.
A12. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio anterior realizar un programa que resuelva lo siguiente: Dado un vector de cinco elementos (cada elemento es una celda de memoria de la mquina Abacus) almacenados a partir de la direccin 200(16), intercambiar de posicin al primer elemento del vector con el mximo. Por ejemplo, si el vector fuera: 4 5 8 7 1, debe quedar: 8 5 4 7 1
A13. - Dada una mquina Abacus con las siguientes caractersticas: CO = 3 bits OP = 6 bits
Operaciones disponibles: (Cdigos en binario) 000 Carga inmediata 111 Fin de Programa 001 Carga 010 Almacena 011 Suma 100 Complemento a la base menos uno (AC) 101 Bifurca incondicionalmente 110 Bifurca si (AC) > 0 Punto de carga en la celda 001111 (2). Determinar el tamao de todos los componentes de la mquina y realizar un programa que resuelva lo siguiente: Calcular A - 2B y almacenar el resultado en la direccin 111100(2) si es positivo y en la 111101(2) en caso contrario. Los valores de A y B se encuentran almacenados en las celdas 110000(2) y 110001(2) respectivamente. A14. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 realizar un programa que resuelva lo siguiente:
Gua de Ejercicios Abacus Versin 1.1 Pgina 5 de 9
75.03 Organizacin del Computador Dado un vector almacenado a partir de la celda 200(16) y que termina en 1(10) se pide invertir al vector, es decir, el ltimo elemento queda en el lugar del primero, (en la celda 200(16) queda el -1(10)), en el anteltimo queda el segundo, etc. A15. Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 realizar un programa que resuelva lo siguiente: La celda 200(16) contiene una direccin de memoria. La celda 201(16) contiene otra direccin de memoria mayor o igual que la anterior. Se pide cambiar unos por ceros y ceros por unos en todas las celdas dentro del bloque delimitado por las dos direcciones mencionadas (inclusive). A16. - Dada una mquina Abacus con las siguientes caractersticas: CO = 4 bits OP = 12 bits
Operaciones disponibles: (Cdigos en hexadecimal) 0: Carga inmediata 4: Suma 1 al AC. 1: Carga. 5: Bifurca si AC < 0 2: Almacenamiento. 6: Resta 3: Suma 7: Bifurca si AC = 0 8: Fin de programa. Sabiendo que en la direccin 1A0(16) se encuentra la direccin de inicio de un vector, cuyo fin est indicado con una celda con valor negativo, se pide realizar un programa Abacus que ubique al principio del vector todos los elementos distintos de cero y al final del mismo los iguales a cero (debe mantener en su lugar la marca de fin de vector). El punto de carga del programa ser la celda 200(16). A17. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 realizar un programa que resuelva lo siguiente: Se sabe que en la direccin 3A0(16) se encuentra la direccin de inicio del primer nodo de una lista cuyos nodos estn formados por dos celdas contiguas. La primera celda de cada nodo contiene un valor en BPF c/signo de 16 bits y la segunda contiene la direccin de inicio del nodo siguiente. En el ltimo nodo la segunda celda contiene un -1(10) para indicar el fin de la lista. Se pide recorrer todos los nodos de la lista y almacenar la sumatoria de todos los BPF c/signo de 16bits. Dicha sumatoria se deber almacenar en la celda 400(16). A18. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 y que no cancela por overflow, realizar un programa que resuelva lo siguiente:
Pgina 6 de 9
75.03 Organizacin del Computador Se tiene una lista formada por nodos que estn compuestos de 3 celdas contiguas cada uno. La primera y segunda celda contienen en conjunto un BP Flotante IEEE 754 de 32bits. (La primera celda contiene los primeros 2 bytes del flotante y la segunda los ltimos 2 bytes). La tercera celda contiene la direccin de inicio del nodo siguiente de la lista. Se sabe que en la direccin 3A0(16) se encuentra la direccin de inicio del primer nodo de la lista. En el ltimo nodo la tercer celda contiene un -1(10) para indicar el fin de la lista. Se pide recorrer todos los nodos de la lista y contar cuantos de los BP Flotante IEEE 754 de 32bits corresponden al formato Normalizado (exp. en exceso distinto de 0(10) y 255(10)). Almacenar el contador en la celda cuya direccin se encuentra almacenada en la celda 300(16). A19. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 realizar un programa que resuelva lo siguiente: Se tiene en memoria un vector formado por elementos de 2 celdas de longitud. En cada elemento la primera celda contiene un valor y la segunda un contenido indefinido inicialmente. El ltimo elemento del vector tiene un valor 0 en la primera celda. Todos los dems elementos del vector tienen como valor en la primera celda nmeros positivos o negativos. Se sabe que en la celda 30A(16) se encuentra almacenada la direccin del primer elemento del vector. Se pide recorrer el vector y "encadenar" los elementos que tengan nmeros positivos en sus celdas valor. Este encadenamiento se llevar a cabo poniendo en la segunda celda de cada elemento la direccin del prximo elemento de la cadena. La direccin del primer elemento de la cadena se deber almacenar en la celda 300(16) y en el ltimo elemento de la cadena se deber dejar un -1(10) en la segunda celda. Por ejemplo si el vector fuera (suponiendo que comienza en la celda 500(16)): (300) XXXX . . . (500) 0FE3 (501) XXXX (502) F33A (503) XXXX (504) 15AB (505) XXXX (506) 00FA (507) XXXX (508) 0000 (509) XXXX El encadenamiento resultante sera: (300) 0500 . . . (500) 0FE3 (501) 0504 (502) F33A (503) XXXX (505) 0506 (506) 00FA (507) FFFF (508) 0000 (509) XXXX
(504) 15AB
A20. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 realizar un programa que resuelva lo siguiente: Se tiene en memoria una lista formada por elementos de 2 celdas de longitud. En cada elemento la primera celda contiene un valor y la segunda, la direccin del siguiente elemento. El ltimo elemento de la lista tiene -1(10) como direccin del siguiente elemento. Se sabe que en la celda 330(16) se encuentra almacenada la direccin del primer elemento de la lista. Se pide pasar todos los valores de la lista (es decir las primeras celdas de cada elemento) a un vector que comience en la direccin 400(16). Se sabe que los elementos de la lista se encuentran todos entre las celdas 200(16) y 500(16) y que la cantidad de elementos de la lista es menor a 60(10).
Gua de Ejercicios Abacus Versin 1.1 Pgina 7 de 9
75.03 Organizacin del Computador Por ejemplo si la lista fuera (suponiendo que la lista comienza en la 220(16)): (220) 0001 (221) 0226 (222) 0003 (223) 0224 (224) 0004 (225) FFFF (226) 0002 (227) 0222 A partir de la direccin 330(16) debe quedar: (330) 0001 (331) 0002 (333) 0003 (334) 0004 A21. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 realizar un programa que resuelva lo siguiente: Se tiene una lista (L) en donde cada nodo contiene una celda que apunta al inicio de un vector de celdas (V) y otra celda que contiene la direccin del siguiente nodo de la lista. El vector de celdas contiene en cada celda un BPF sin signo de 12 bits y termina con un valor 0. A su vez el final de la lista est determinado por un valor -1(10) en la segunda celda del ltimo nodo. Se pide realizar un programa Abacus que recorra todas las celdas de los vectores (V) de todos los nodos de la lista (L) y obtenga el mximo BPF sin signo almacenado. Este valor se deber dejar almacenado en la celda 200(16). La celda 300(16) contiene la direccin de inicio de L. L
V1
V2
V3
A22. - Dada una mquina Abacus con las mismas caractersticas y operaciones disponibles que el ejercicio A11 realizar un programa que resuelva lo siguiente: Se tiene un vector de celdas (V) cuyos elementos son punteros a listas (L). Cada nodo de cada lista est formado a su vez por dos celdas contiguas en memoria. La primera celda contiene un BPF c/signo de 16 bits y la otra celda contiene la direccin del siguiente nodo de la lista. Cada lista termina con un valor -1(10) en la segunda celda del ltimo nodo. El vector (V) termina con un valor 0(10) en su ltima celda. Se pide recorrer todos los nodos de cada lista y hacer la productoria de sus elementos. Se deber dejar en la celda 200(16) la menor de todas las productorias calculadas y en la celda 201(16) la direccin de la celda del vector (V) que corresponda a la lista a partir de la cual se gener dicha productoria. La celda 300(16) contiene la direccin de inicio del vector (V).
Pgina 8 de 9
...
-1
-1
A23. Dada una mquina Abacus con las siguientes caractersticas: RPI = 12 bits AC = 16 bits
Operaciones disponibles: (Cdigos en hexadecimal) 0 Carga inmediata 7 Bifurcacin si (AC) = 0 1 Cargar 8 Bifurcacin si (AC) > 0 2 Almacenar 9 Bifurcacin si (AC) < 0 3 Sumar F Fin de Programa 6 Not (AC) Se tiene una lista (L) cuya direccin de inicio se encuentra almacenada en la celda 200(16). Cada nodo de la lista (L) est formado por tres celdas contiguas en memoria. La primera celda contiene un nmero n que representa la dimensin de una matriz cuadrada de n*n. La segunda celda contiene la direccin de inicio de una matriz (M) cuadrada. La tercera celda del nodo contiene la direccin del siguiente nodo de la lista. El final de la lista (L) se indica con un valor -1 en la tercera celda del ltimo nodo. Se pide realizar un programa ABACUS con punto de carga en la celda 300(16) que recorra todos los nodos de la Lista (L) y calcule la sumatoria de los elementos de la diagonal principal de cada matriz (M) asociada almacenando en la celda 400(16) la minima sumatoria calculada.
200 0 L
...
3 5 -1 3 1 6 2 6 -2
-1
2 4
4 4
-5 9 5
2 400 0
Pgina 9 de 9