Compare commits
10 Commits
master
...
c_programm
Author | SHA1 | Date | |
---|---|---|---|
e92c73260d | |||
8dc104ed91 | |||
fbe148d487 | |||
b2e4931c15 | |||
364fb988e6 | |||
|
f006d56ba6 | ||
|
8337168b18 | ||
6bacd41503 | |||
|
c6b12cf78e | ||
|
78d882b0f6 |
4
.gitignore
vendored
Normal file
4
.gitignore
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
.idea
|
||||||
|
cmake-buid-debug
|
||||||
|
# Executables
|
||||||
|
*.exe
|
14
README.md
14
README.md
@ -2,8 +2,14 @@
|
|||||||
**Терминал**.
|
**Терминал**.
|
||||||
Устройство представляет из себя микроконтроллер с клавиатурой (матрица 4 х 4) и подключенное устройство из задания №5. Простейший калькулятор.
|
Устройство представляет из себя микроконтроллер с клавиатурой (матрица 4 х 4) и подключенное устройство из задания №5. Простейший калькулятор.
|
||||||
# Список участников
|
# Список участников
|
||||||
**Батухтин Михаил\n**
|
* Батухтин Михаил
|
||||||
**Бочкина Кристина\n**
|
* Бочкина Кристина
|
||||||
**Уткин Никита\n**
|
* Уткин Никита
|
||||||
**Хромова Полина\n**
|
* Хромова Полина
|
||||||
|
|
||||||
|
## Части задачи
|
||||||
|
- GPIO + GPIO в контексте Atmega328. Pull up, Pull down (Михаил Батухтин/Уткин Никита)
|
||||||
|
- Физическая реализация клавиатуры (Кристина Бочкина/Полина Хромова)
|
||||||
|
- SPI интерфейс + SPI у Atmega328 (Кристина Бочкина)
|
||||||
|
- Программная реализация клавиатуры (Полина Хромова)
|
||||||
|
- Архитектура ПО (Михаил Батухтин)
|
||||||
|
204
c_programm
Normal file
204
c_programm
Normal file
@ -0,0 +1,204 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
enum calculator_state
|
||||||
|
{
|
||||||
|
NUMBER_FIRST,
|
||||||
|
NUMBER_SECOND,
|
||||||
|
RESULT
|
||||||
|
};
|
||||||
|
|
||||||
|
enum calculator_op
|
||||||
|
{
|
||||||
|
NO_OP,
|
||||||
|
ADD,
|
||||||
|
SUB,
|
||||||
|
DIV,
|
||||||
|
MUL
|
||||||
|
};
|
||||||
|
struct calculator
|
||||||
|
{
|
||||||
|
// 1 число
|
||||||
|
int num1;
|
||||||
|
// 2 число
|
||||||
|
int num2;
|
||||||
|
// 3 операция
|
||||||
|
enum calculator_op operation;
|
||||||
|
// 4 результат
|
||||||
|
double result;
|
||||||
|
// 5 состояние атомата
|
||||||
|
enum calculator_state state;
|
||||||
|
};
|
||||||
|
|
||||||
|
// double calculate(char op, double num1, double num2) {
|
||||||
|
// double result = 0;
|
||||||
|
// switch (op) {
|
||||||
|
// case '+':
|
||||||
|
// result = num1 + num2;
|
||||||
|
// break;
|
||||||
|
// case '-':
|
||||||
|
// result = num1 - num2;
|
||||||
|
// break;
|
||||||
|
// case '*':
|
||||||
|
// result = num1 * num2;
|
||||||
|
// break;
|
||||||
|
// case '/':
|
||||||
|
// result = num1 / num2;
|
||||||
|
// break;
|
||||||
|
// }
|
||||||
|
// return result;
|
||||||
|
// }
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
struct calculator calc;
|
||||||
|
calc.state = NUMBER_FIRST;
|
||||||
|
calc.operation = NO_OP;
|
||||||
|
calc.num1 = 0;
|
||||||
|
calc.num2 = 0;
|
||||||
|
calc.result = 0;
|
||||||
|
|
||||||
|
char input;
|
||||||
|
while (1)
|
||||||
|
{
|
||||||
|
scanf("%d", &input);
|
||||||
|
switch (calc.state)
|
||||||
|
{
|
||||||
|
case NUMBER_FIRST:
|
||||||
|
switch (input)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 7;
|
||||||
|
printf("%d",calc.num1);
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 8;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 9;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
calc.operation = DIV;
|
||||||
|
calc.state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 4;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 5;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 6;
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
calc.operation = MUL;
|
||||||
|
calc.state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 1;
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 2;
|
||||||
|
case 10:
|
||||||
|
calc.num1 = (calc.num1 * 10) + 3;
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
calc.operation = SUB;
|
||||||
|
calc.state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
calc.num1 = 0;
|
||||||
|
break;
|
||||||
|
case 13:
|
||||||
|
calc.state = NUMBER_FIRST;
|
||||||
|
calc.operation = NO_OP;
|
||||||
|
calc.num1 = 0;
|
||||||
|
calc.num2 = 0;
|
||||||
|
calc.result = 0;
|
||||||
|
break;
|
||||||
|
case 14:
|
||||||
|
break;
|
||||||
|
case 15:
|
||||||
|
calc.operation = ADD;
|
||||||
|
calc.state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
case NUMBER_SECOND:
|
||||||
|
switch (input)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 7;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 8;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 9;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 4;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 5;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 6;
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 1;
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 2;
|
||||||
|
case 10:
|
||||||
|
calc.num2 = (calc.num2 * 10) + 3;
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
calc.num2 = 0;
|
||||||
|
break;
|
||||||
|
case 13:
|
||||||
|
calc.state = NUMBER_FIRST;
|
||||||
|
calc.operation = NO_OP;
|
||||||
|
calc.num1 = 0;
|
||||||
|
calc.num2 = 0;
|
||||||
|
calc.result = 0;
|
||||||
|
break;
|
||||||
|
case 14:
|
||||||
|
calc.state = RESULT;
|
||||||
|
break;
|
||||||
|
case 15:
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case RESULT:
|
||||||
|
switch (calc.operation)
|
||||||
|
{
|
||||||
|
case ADD:
|
||||||
|
calc.result = calc.num1 + calc.num2;
|
||||||
|
break;
|
||||||
|
case SUB:
|
||||||
|
calc.result = calc.num1 - calc.num2;
|
||||||
|
break;
|
||||||
|
case MUL:
|
||||||
|
calc.result = calc.num1 * calc.num2;
|
||||||
|
break;
|
||||||
|
case DIV:
|
||||||
|
calc.result = calc.num1 / calc.num2;
|
||||||
|
break;
|
||||||
|
return calc.result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
143
calculator.c
Normal file
143
calculator.c
Normal file
@ -0,0 +1,143 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include "calculator.h"
|
||||||
|
|
||||||
|
void handleCalc(struct calculator *calc, int input) {
|
||||||
|
switch (calc->state) {
|
||||||
|
case NUMBER_FIRST:
|
||||||
|
switch (input) {
|
||||||
|
case 0:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 7;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 8;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 9;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
calc->operation = DIV;
|
||||||
|
calc->state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 4;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 5;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 6;
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
calc->operation = MUL;
|
||||||
|
calc->state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 1;
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 2;
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
calc->num1 = (calc->num1 * 10) + 3;
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
calc->operation = SUB;
|
||||||
|
calc->state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
calc->num1 = (calc->num1 * 10);
|
||||||
|
break;
|
||||||
|
case 13:
|
||||||
|
clearCalc(calc);
|
||||||
|
break;
|
||||||
|
case 14:
|
||||||
|
break;
|
||||||
|
case 15:
|
||||||
|
calc->operation = ADD;
|
||||||
|
calc->state = NUMBER_SECOND;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NUMBER_SECOND:
|
||||||
|
switch (input) {
|
||||||
|
case 0:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 7;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 8;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 9;
|
||||||
|
break;
|
||||||
|
case 3:
|
||||||
|
break;
|
||||||
|
case 4:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 4;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 5;
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 6;
|
||||||
|
break;
|
||||||
|
case 7:
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 1;
|
||||||
|
break;
|
||||||
|
case 9:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 2;
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
calc->num2 = (calc->num2 * 10) + 3;
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
break;
|
||||||
|
case 12:
|
||||||
|
calc->num2 = (calc->num2 * 10);
|
||||||
|
break;
|
||||||
|
case 13:
|
||||||
|
clearCalc(calc);
|
||||||
|
break;
|
||||||
|
case 14:
|
||||||
|
switch (calc->operation) {
|
||||||
|
case ADD:
|
||||||
|
calc->result = calc->num1 + calc->num2;
|
||||||
|
calc->state = RESULT;
|
||||||
|
break;
|
||||||
|
case SUB:
|
||||||
|
calc->result = calc->num1 - calc->num2;
|
||||||
|
calc->state = RESULT;
|
||||||
|
break;
|
||||||
|
case MUL:
|
||||||
|
calc->result = calc->num1 * calc->num2;
|
||||||
|
calc->state = RESULT;
|
||||||
|
break;
|
||||||
|
case DIV:
|
||||||
|
calc->result = calc->num1 / calc->num2;
|
||||||
|
calc->state = RESULT;
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 15:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case RESULT:
|
||||||
|
switch (input) {
|
||||||
|
case 14:
|
||||||
|
clearCalc(calc);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void clearCalc(struct calculator* calc) {
|
||||||
|
calc->state = NUMBER_FIRST;
|
||||||
|
calc->operation = NO_OP;
|
||||||
|
calc->num1 = 0;
|
||||||
|
calc->num2 = 0;
|
||||||
|
calc->result = 0;
|
||||||
|
}
|
32
calculator.h
Normal file
32
calculator.h
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
#ifndef TESTCALC_MAIN_H
|
||||||
|
#define TESTCALC_MAIN_H
|
||||||
|
|
||||||
|
enum calculator_state {
|
||||||
|
NUMBER_FIRST,
|
||||||
|
NUMBER_SECOND,
|
||||||
|
RESULT
|
||||||
|
};
|
||||||
|
enum calculator_op {
|
||||||
|
NO_OP,
|
||||||
|
ADD,
|
||||||
|
SUB,
|
||||||
|
DIV,
|
||||||
|
MUL
|
||||||
|
};
|
||||||
|
struct calculator {
|
||||||
|
// 1 число
|
||||||
|
int num1;
|
||||||
|
// 2 число
|
||||||
|
int num2;
|
||||||
|
// 3 операция
|
||||||
|
enum calculator_op operation;
|
||||||
|
// 4 результат
|
||||||
|
int result;
|
||||||
|
// 5 состояние атомата
|
||||||
|
enum calculator_state state;
|
||||||
|
};
|
||||||
|
|
||||||
|
void clearCalc(struct calculator *calc);
|
||||||
|
void handleCalc(struct calculator *calc, int input);
|
||||||
|
|
||||||
|
#endif //TESTCALC_MAIN_H
|
13
main.c
Normal file
13
main.c
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include "calculator.h"
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
struct calculator calc;
|
||||||
|
clearCalc(&calc);
|
||||||
|
int input;
|
||||||
|
while (1) {
|
||||||
|
scanf("%d", &input);
|
||||||
|
handleCalc(&calc, input);
|
||||||
|
printf("num1: %d | num2: %d | result: %d | operation: %d | state: %d", calc.num1, calc.num2, calc.result, calc.operation, calc.state);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user