Files
algorithm/lab1/CellularAutomaton.h

28 lines
575 B
C++

#pragma once
#include <vector>
#include <random>
#include <iostream>
#include "io.h"
class CellularAutomaton
{
static const unsigned int functionValues = 0b00000110100000000010110010110110;
int m_fieldWidth, m_fieldHeight;
std::vector<std::vector<int>> field;
std::vector<std::vector<int>> fieldNextState;
void initializeRandom();
void initializeManual();
int getCellState(int x, int y) const;
int getNeighborhoodIndex(int x, int y) const;
public:
CellularAutomaton(int width, int height, bool fillWithRandom);
void update();
void displayField() const;
};