[Logo] Форум DL
  [DL]  На главную страницу 
Индекс форума ->Учебный процесс ГГУ/СШ 27 ->Проектирование цифровых систем 1, 2, 3, ... 19, 20, 21, 22, 23, 24, 25, 26
Автор Сообщение
Яна Ясиновская

Темы: 0
Сообщений: 26

Мой профиль


Яна Ясиновская:

Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2021
Командные олимпиады\Микропрограммирование на С-МПА\Контрольный срез (Пример 1)\Проектирование\ПА - "Memory" (53757)
http://dl.gsu.by/task.jsp?nid=2027974&cid=1230

unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{
 	if((A + B + C + D + E + F) % 2 == 0) pamat = 0;
 	else if(((A + B + C + D + E + F) % 2 != 0) && ((A + B + C + D + E + F) > 3)) pamat = D;
 	Q = pamat;
}

Ошибка: Несовпадение Q:0=1 [10 ns]
unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{
 	if((A + B + C + D + E + F) % 2 == 0) pamat = 0;
 	else if(((A + B + C + D + E + F) % 2 != 0) || ((A + B + C + D + E + F) > 3)) pamat = D;
 	Q = pamat;
}

Ошибка: Несовпадение Q:0=1 [20 ns]


unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{
	int sum = A + B + C + D + E + F;
 	if((sum % 2) == 0) pamat = 0;
 	else if(sum > 3) pamat = D;
 	Q = pamat;
}

Ошибка: Несовпадение Q:0=1 [10 ns]

unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{
	unsigned __bits(1) TA;
	unsigned __bits(1) TB;
	unsigned __bits(1) TC;
	unsigned __bits(1) TD;
	unsigned __bits(1) TE;
	unsigned __bits(1) TF;
	unsigned __bits(3) sum = TA + TB + TC + TD + TE + TF;
 	if((sum % 2) == 0) pamat = 0;
 	else if(sum > 3) pamat = TD;
 	Q = pamat;
}

Для значений TA=1 , TB = 1, TC = 1, TD = 1, TE = 1, TF = 1 sum = 2


unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{
	unsigned __bits(1) TA;
	unsigned __bits(1) TB;
	unsigned __bits(1) TC;
	unsigned __bits(1) TD;
	unsigned __bits(1) TE;
	unsigned __bits(1) TF;
	unsigned __bits(3) sum;
	sum = TA ;
	sum += TB;
	sum += TC;
	sum += TD;
	sum += TE;
	sum += TF;
 	if((sum % 2) == 0) pamat = 0;
 	else if(sum > 3) pamat = TD;
 	Q = pamat;
}

  
   A B C D E F   Q 
 1 0 0 0 0 0 0   0
 2 1 1 1 1 1 1   0
 3 1 1 1 1 0 0   0
 4 1 0 1 0 1 1   0
 5 1 0 1 0 0 0   0
 6 1 1 1 0 1 1   0
 7 1 1 1 1 0 1   1
 8 0 1 1 1 1 1   1
 9 0 0 1 0 1 1   1

unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{
	unsigned __bits(1) TA;
	unsigned __bits(1) TB;
	unsigned __bits(1) TC;
	unsigned __bits(1) TD;
	unsigned __bits(1) TE;
	unsigned __bits(1) TF;
	unsigned __bits(3) sum;
	sum = TA ;
	sum += TB;
	sum += TC;
	sum += TD;
	sum += TE;
	sum += TF;
 	if((sum % 2) == 0) pamat = 0;
 	else if(sum > 3) pamat = TD;
 	Q = pamat;
}

РЕШЕНИЕ ПРОШЛО!!!
В winter правильный ответ, добавила в окно переменные ,сделала новую папку, туда отправила свой проект, сгенерировала 



unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{
	unsigned __bits(3) sum;
	sum = A ;
	sum += B;
	sum += C;
	sum += D;
	sum += E;
	sum += F;
 	if((sum % 2) == 0) pamat = 0;
 	else if(sum > 3) pamat = D;
 	Q = pamat;
}

Убрала временные переменные - решение не прошло


unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{

	unsigned __bits(1) TA;
	unsigned __bits(1) TB;
	unsigned __bits(1) TC;
	unsigned __bits(1) TD;
	unsigned __bits(1) TE;
	unsigned __bits(1) TF;
	TA = A; TB = B; TC = C; TD = D; TE = E; TF = F;
	unsigned __bits(3) sum;
	sum = TA;
	sum += TB;
	sum += TC;
	sum += TD;
	sum += TE;
	sum += TF;
 	if((sum % 2) == 0) pamat = 0;
 	else if(sum > 3) pamat = TD;
 	Q = pamat;
}

ЭТО ПРОШЛО
Игорь Коршунов

Темы: 7
Сообщений: 2186

Мой профиль


Яна Ясиновская:

Убрала временные переменные - решение не прошло


unsigned __in __bits(1) A;
unsigned __in __bits(1) B;
unsigned __in __bits(1) C;
unsigned __in __bits(1) D;
unsigned __in __bits(1) E;
unsigned __in __bits(1) F;

unsigned __out __bits(1) Q;

unsigned __bits(1) pamat;


void main()
{

	unsigned __bits(1) TA;
	unsigned __bits(1) TB;
	unsigned __bits(1) TC;
	unsigned __bits(1) TD;
	unsigned __bits(1) TE;
	unsigned __bits(1) TF;
	TA = A; TB = B; TC = C; TD = D; TE = E; TF = F;
	unsigned __bits(3) sum;
	sum = TA;
	sum += TB;
	sum += TC;
	sum += TD;
	sum += TE;
	sum += TF;
 	if((sum % 2) == 0) pamat = 0;
 	else if(sum > 3) pamat = TD;
 	Q = pamat;
}

ЭТО ПРОШЛО 


Для задач с памятью нужно сохранять входные данные во временные переменные в самом начале программы. Без этого память может быть испорчена.
Например, мы просуммировали A+B+C и в это время изменились входные данные. Далее мы добавляем D+E+F из нового теста к числу A+B+C из старого теста. Получаем случайное число, из-за которого можем записать в память неверное значение.

Ссылка из первого сообщения темы:

http://dl.gsu.by/NForum/posts/topicshow/46.dl?postid=57446#57446
Дарья Самусева

Темы: 0
Сообщений: 4

Мой профиль
http://dl.gsu.by/task.jsp?nid=2027979&cid=1230

Командные олимпиады\Микропрограммирование на С-МПА\Контрольный срез (Пример 1)\Программирование\ЦЧ - "Работа с числом"

В этой задаче в условии указана переменная А, компилятор требует переменную а: "[1]: Не объявлена переменная a. "
Игорь Коршунов

Темы: 7
Сообщений: 2186

Мой профиль


Дарья Самусева:

http://dl.gsu.by/task.jsp?nid=2027979&cid=1230

Командные олимпиады\Микропрограммирование на С-МПА\Контрольный срез (Пример 1)\Программирование\ЦЧ - "Работа с числом"

В этой задаче в условии указана переменная А, компилятор требует переменную а: "[1]: Не объявлена переменная a. " 


Вот отправленная на тестирование программа:
unsigned __bits(8) b[20];
unsigned __out __bits(8) kol;

void main(){
  unsigned __bits(8) i;
  unsigned __bits(8) s=0;
  for (i=0;	i<20; i++)
    if (b[i]<4)
	  s++;
  kol=s;

}

Это явно решение какой-то другой задачи. В этой программе просто нет переменной А.
Даниил Коханов

Темы: 1
Сообщений: 17

Мой профиль
Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2022
Экзамен\Контроль практики\Проектирование\3\HLCCAD-Plus\1 - "4-битный знаковый компаратор на ЛЭ" (129590)
http://dl.gsu.by/task.jsp?nid=2248846&cid=1282

int __in __bits(4) X = 0;
int __in __bits(4) Y = -8;
unsigned __out __bits(1) B;
unsigned __out __bits(1) M;
unsigned __out __bits(1) R;



void main() {
  if(X == Y) {
    R = 1;
  } else{
      R	= 0;
    }

  if(X > Y) {
    B = 1;
  } else{
      B	= 0;
    }

  if(X < Y) {
    M = 1;
  } else{
      M	= 0;
    }
  
}


В программе получили правильный ответ, но сгенерированный hlсcad проект не проходит

30.9 14:33 1. 4-битный знаковый компаратор на ЛЭ 0 / 100 Ошибка: Несовпадение B:0=1 [3 ns] DelTA3 at NIT0 HLCCAD project
Максим Кадетов

Темы: 0
Сообщений: 6

Мой профиль
Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2022
Экзамен\Контроль практики\Проектирование\3\HLCCAD\5 - "Сравнение двух сумм" (41751)
http://dl.gsu.by/task.jsp?nid=2248839&cid=1282

unsigned __in __bits(4) a_1;
unsigned __in __bits(4) a_2;
unsigned __in __bits(1) a_3;
unsigned __in __bits(4) b_1;
unsigned __in __bits(4) b_2;
unsigned __in __bits(1) b_3;

unsigned __out __bits(1) cmp1;
unsigned __out __bits(1) cmp2;
unsigned __out __bits(1) cmp3;

void main() {
	unsigned __in __bits(5) sum1 = a_1 + a_2 + a_3;
	unsigned __in __bits(5) sum2 = b_1 + b_2 + b_3;
	unsigned __bits(1) ccmp1;
	unsigned __bits(1) ccmp2;
	unsigned __bits(1) ccmp3;

	if (sum1 > sum2) {
		ccmp1 = 1;
		ccmp2 = 0;
		ccmp3 = 0;
	}
	else
		if (sum1 == sum2) {
			ccmp1 = 0;
			ccmp2 = 1;
			ccmp3 = 0;
		}
		else {
			ccmp1 = 0;
			ccmp2 = 0;
			ccmp3 = 1;
		}

	cmp1 = ccmp1;
	cmp2 = ccmp2;
	cmp3 = ccmp3;
}


Микропрограмма выдаёт правильный ответ, а сгенерированный HLCCAD-проект не принимается.

30.9 15:25 5. Сравнение двух сумм 0 / 100 Ошибка: Несовпадение cmp1:0=1 [5,004 ps] DelTA3 at NIT8 HLCCAD project
Игорь Коршунов

Темы: 7
Сообщений: 2186

Мой профиль


Максим Кадетов:

Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2022
Экзамен\Контроль практики\Проектирование\3\HLCCAD\5 - "Сравнение двух сумм" (41751)
http://dl.gsu.by/task.jsp?nid=2248839&cid=1282

unsigned __in __bits(4) a_1;
unsigned __in __bits(4) a_2;
unsigned __in __bits(1) a_3;
unsigned __in __bits(4) b_1;
unsigned __in __bits(4) b_2;
unsigned __in __bits(1) b_3;

unsigned __out __bits(1) cmp1;
unsigned __out __bits(1) cmp2;
unsigned __out __bits(1) cmp3;

void main() {
	unsigned __in __bits(5) sum1 = a_1 + a_2 + a_3;
	unsigned __in __bits(5) sum2 = b_1 + b_2 + b_3;
	unsigned __bits(1) ccmp1;
	unsigned __bits(1) ccmp2;
	unsigned __bits(1) ccmp3;

	if (sum1 > sum2) {
		ccmp1 = 1;
		ccmp2 = 0;
		ccmp3 = 0;
	}
	else
		if (sum1 == sum2) {
			ccmp1 = 0;
			ccmp2 = 1;
			ccmp3 = 0;
		}
		else {
			ccmp1 = 0;
			ccmp2 = 0;
			ccmp3 = 1;
		}

	cmp1 = ccmp1;
	cmp2 = ccmp2;
	cmp3 = ccmp3;
}


Микропрограмма выдаёт правильный ответ, а сгенерированный HLCCAD-проект не принимается.

30.9 15:25 5. Сравнение двух сумм 0 / 100 Ошибка: Несовпадение cmp1:0=1 [5,004 ps] DelTA3 at NIT8 HLCCAD project  

sum1 и sum2 объявлены как входные контакты, __in нужно убрать.
Игорь Коршунов

Темы: 7
Сообщений: 2186

Мой профиль


Даниил Коханов:

Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2022
Экзамен\Контроль практики\Проектирование\3\HLCCAD-Plus\1 - "4-битный знаковый компаратор на ЛЭ" (129590)
http://dl.gsu.by/task.jsp?nid=2248846&cid=1282

int __in __bits(4) X = 0;
int __in __bits(4) Y = -8;
unsigned __out __bits(1) B;
unsigned __out __bits(1) M;
unsigned __out __bits(1) R;



void main() {
  if(X == Y) {
    R = 1;
  } else{
      R	= 0;
    }

  if(X > Y) {
    B = 1;
  } else{
      B	= 0;
    }

  if(X < Y) {
    M = 1;
  } else{
      M	= 0;
    }
  
}


В программе получили правильный ответ, но сгенерированный hlсcad проект не проходит

30.9 14:33 1. 4-битный знаковый компаратор на ЛЭ 0 / 100 Ошибка: Несовпадение B:0=1 [3 ns] DelTA3 at NIT0 HLCCAD project  

Эта программа правильная, сгенерированная схема прошла все тесты.
Возможно, ты сдавал схему сгенерированную не по этой программе.
Анна Гладкова

Темы: 0
Сообщений: 5

Мой профиль
Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2022
Экзамен\Контроль практики\Проектирование\4\Проектирование в HLCCAD\2 - "Дробь" (39297)
http://dl.gsu.by/task.jsp?nid=2248863&cid=1282

unsigned __in __bits(1) in_3;
unsigned __in __bits(1) in_2;
unsigned __in __bits(1) in_1;
unsigned __in __bits(1) in_0;

unsigned __out __bits(1) out_3;
unsigned __out __bits(1) out_2;
unsigned __out __bits(1) out_1;
unsigned __out __bits(1) out_0;

void main() {
  unsigned __bits(1) x1, x2, x3, x4, nx1, nx2, nx3, nx4;
  x1 = in_3;  nx1 = ~in_3;
  x2 = in_2;  nx2 = ~in_2;
  x3 = in_1;  nx3 = ~in_1;
  x4 = in_0;  nx4 = ~in_0;
  out_3 = x1 & x2;
  out_2 = x1 & nx2 | nx1 & x2 & x3;
  out_1 = nx1 &	x2 & nx3 | x1 & nx2 & x4 | x1 & nx2 & x3 | x3 & x4 & x1 | x3 & x4 & nx2;
  out_0 = nx1 & nx3 & x4 | nx1 & nx2 & x3 & nx4 | x1 & x2 & x3 & nx4 | x1 & nx2 & nx3 & nx4 | x1 &nx2 & x3 & x4;
}

Роман Мицура

Темы: 0
Сообщений: 9

Мой профиль
unsigned __in __bits(8) A = 255;
unsigned __in __bits(8) B = 157;
unsigned __in __bits(8) C = 0;
unsigned __in __bits(8) D = 148;

unsigned __out __bits(8) E;

void main(){
	int	k1,k2,k3,k4;
	int sred,sred1;
	sred = A;
	sred = sred + B;
	sred = sred + C;
	sred = sred + D;
	sred = sred/4;
	sred1 = (A+B+C+D)/4;
    k1 = A - sred;
	k2 = B - sred;
    k3 = C - sred;
	k4 = D - sred;
	if(k1<0)
	  k1 = k1*(-1);
	if(k2<0)
	  k2 = k2*(-1);
	if(k3<0)
	  k3 = k3*(-1);
	if(k4<0)
	  k4 = k4*(-1);
	if((k1>=k2)&&(k1>=k3)&&(k1>=k4))
	  E = k1;
    if((k2>=k1)&&(k2>=k3)&&(k2>=k4))
	  E = k2;
    if((k3>=k2)&&(k3>=k1)&&(k3>=k4))
	  E = k3;
    if((k4>=k2)&&(k4>=k3)&&(k4>=k1))
	  E = k4;
}

sred считается правильно, sred1 не правильно
Игорь Коржов

Темы: 0
Сообщений: 7

Мой профиль
unsigned __in __bits(1) x1 = 1;
unsigned __in __bits(1) x2 = 1;
unsigned __in __bits(1) x3 = 0;
unsigned __in __bits(1) x4 = 1;
unsigned __out __bits(1) y1;
unsigned __out __bits(1) y2;
unsigned __out __bits(1) y3;
unsigned __out __bits(1) y4;

void main(){
   if (~x1 && ~x2 && ~x3 && ~x4) {
	y1 = 0;
	y2 = 1;
	y3 = 0;
	y4 = 0;
   }
}

Если просто отрицать значения через ~ то условие работает неправильно
Если создать дополнительные переменные то все будет работать
Если работать просто с & то тоже работает неправильно
unsigned __in __bits(1) x1 = 1;
unsigned __in __bits(1) x2 = 1;
unsigned __in __bits(1) x3 = 0;
unsigned __in __bits(1) x4 = 1;
unsigned __out __bits(1) y1;
unsigned __out __bits(1) y2;
unsigned __out __bits(1) y3;
unsigned __out __bits(1) y4;

void main(){
   unsigned __in __bits(1) x11 = ~x1;
   unsigned __in __bits(1) x22 = ~x2;
   unsigned __in __bits(1) x33 = ~x3;
   unsigned __in __bits(1) x44 = ~x4;
   if (x11 && x22 && x33 && x44) {
	y1 = 0;
	y2 = 1;
	y3 = 0;
	y4 = 0;
   }
}

Арман Сорокин

Темы: 0
Сообщений: 11

Мой профиль
Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2022
Контрольные срезы\26 сентября\Проектирование\Простые устройства с памятью\2 - "Арифметика" (53810)
http://dl.gsu.by/task.jsp?nid=2240401&cid=1282

14.10 16:52 2. Арифметика 0 / 1 Ошибка: Несовпадение RES:00000001=10 [9 ns] DelTA3 at NIT8 HLCCAD project

unsigned __in __bits(2) A = 1;
unsigned __in __bits(2) B = 2;
unsigned __in __bits(2) C = 1;

unsigned __out __bits(8) RES;

unsigned __bits(8) mem;

void main()
{
  if ((A * B) < (C + 1))
  {
    mem = 0;
    RES = 0;
  }
  else if ((A * B) > (C + 1))
  {
    mem = A * B - C;
	RES = mem;
  }
  else
  {
    RES = mem;
  }
}

Антон Ворона

Темы: 0
Сообщений: 11

Мой профиль
int __in __bits(16) a = 10;
int __in __bits(16) b = 910;
int __in __bits(8) c = 10;
int __in __bits(8) d = -1;


int __out __bits(16) RES;


int Modul(int num){
	if (num < 0){
		return (num*(-1));
	}
	else {
		return num;
	}
}

int Sign(int num){
	if (num < 0){
		return -1;
	}
	else if(num > 0){
		return 1;
	}
	else {
		return 0;
	}
}

void main(){
	if (d > 0){
		RES = Modul((a - b) / c) + d * c;
	}
	else{
		int test = Modul(a) - Modul(b);
		int buff = Modul(a);
		int buff2 = Modul(b);
                int test2 = buff - buff2;
		RES = Modul(buff - buff2) * d / c + Sign(a*b*c*d);
	}
}


При отладке программы в методе Main в блоке else имеется ошибка при разнице. Переменная test имеет значение 0, но если вынести Modul(a) и Modul(b) в отдельные переменные, то тогда инструкции выполняются верно, что видно по переменной test2, которая будет иметь значение -900.
Игорь Коршунов

Темы: 7
Сообщений: 2186

Мой профиль


Антон Ворона:

int __in __bits(16) a = 10;
int __in __bits(16) b = 910;
int __in __bits(8) c = 10;
int __in __bits(8) d = -1;


int __out __bits(16) RES;


int Modul(int num){
	if (num < 0){
		return (num*(-1));
	}
	else {
		return num;
	}
}

int Sign(int num){
	if (num < 0){
		return -1;
	}
	else if(num > 0){
		return 1;
	}
	else {
		return 0;
	}
}

void main(){
	if (d > 0){
		RES = Modul((a - b) / c) + d * c;
	}
	else{
		int test = Modul(a) - Modul(b);
		int buff = Modul(a);
		int buff2 = Modul(b);
                int test2 = buff - buff2;
		RES = Modul(buff - buff2) * d / c + Sign(a*b*c*d);
	}
}


При отладке программы в методе Main в блоке else имеется ошибка при разнице. Переменная test имеет значение 0, но если вынести Modul(a) и Modul(b) в отдельные переменные, то тогда инструкции выполняются верно, что видно по переменной test2, которая будет иметь значение -900. 

Из-за отсутствия стека одну и ту же функцию нельзя вызывать в одном выражении. При повторном вызове затирается результат первого и
test = func(x) - func(y);
всегда будет равен нулю.
Николай Афанасенко

Темы: 0
Сообщений: 8

Мой профиль
Архитектура вычислительных систем (ПО4/ИТ3/ПИ2) - 2022
Контрольные срезы\12 сентября \Программирование\Цифры числа\3 - "Перевернутое число" (44766)
http://dl.gsu.by/task.jsp?nid=2239965&cid=1282

int __in __bits(16) x ;

int __out __bits(16) y;

void main(){
    int start = x;
    int fin = 0;
    while(start >= 1){
        int digit = start %10;
        fin += digit;
        fin *=10;
		start /=10;
    }
    fin /=10;
    y = fin;
}


Пишет ошибка в 1 тесте, хотя при проверке всех тестов ответ сходиться
 
Индекс форума ->Учебный процесс ГГУ/СШ 27 ->Проектирование цифровых систем 1, 2, 3, ... 19, 20, 21, 22, 23, 24, 25, 26
Time:0,274