A lot of shit you don't want
This commit is contained in:
		
							parent
							
								
									496c1022db
								
							
						
					
					
						commit
						0ae7892998
					
				| @ -4,28 +4,35 @@ | |||||||
| 
 | 
 | ||||||
| #include "DLASystem.h" | #include "DLASystem.h" | ||||||
| 
 | 
 | ||||||
| // colors
 | #include <utility> | ||||||
| namespace colours { |  | ||||||
|     GLfloat blue[] = {0.1, 0.3, 0.9, 1.0};   // blue
 |  | ||||||
|     GLfloat red[] = {1.0, 0.2, 0.1, 0.2};   // red
 |  | ||||||
|     GLfloat green[] = {0.3, 0.6, 0.3, 1.0};     // green
 |  | ||||||
|     GLfloat paleGrey[] = {0.7, 0.7, 0.7, 1.0};     // green
 |  | ||||||
|     GLfloat darkGrey[] = {0.2, 0.2, 0.2, 1.0};     // green
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| // this function gets called every step,
 | // this function gets called every step,
 | ||||||
| //   if there is an active particle then it gets moved,
 | //   if there is an active particle then it gets moved,
 | ||||||
| //   if not then add a particle
 | //   if not then add a particle
 | ||||||
| void DLASystem::Update() { | bool DLASystem::Update() { | ||||||
|     if (lastParticleIsActive == 1) |     if (lastParticleIsActive == 1) { | ||||||
|         moveLastParticle(); |         moveLastParticle(); | ||||||
|     else if (numParticles < endNum) { |     } else if (numParticles < endNum) { | ||||||
|         addParticleOnAddCircle(); |         addParticleOnAddCircle(); | ||||||
|         setParticleActive(); |         setParticleActive(); | ||||||
|  |     } else { | ||||||
|  |         return false; | ||||||
|     } |     } | ||||||
|     if (lastParticleIsActive == 0 || slowNotFast == 1) | 
 | ||||||
|         glutPostRedisplay(); //Tell GLUT that the display has changed
 |     if (!lastParticleIsActive) { | ||||||
|  |         for (int i = 0; i < numParticles; ++i) { | ||||||
|  |             this->csv_out << this->particleList[i]->pos[0] << "," << this->particleList[i]->pos[1]; | ||||||
|  |             if (i != numParticles - 1) { | ||||||
|  |                 this->csv_out  << ","; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         this->csv_out << "\n"; | ||||||
|  | 
 | ||||||
|  |         this->csv_out.flush(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -88,7 +95,7 @@ int DLASystem::checkStop() { | |||||||
|     if (killCircle + 2 >= gridSize / 2) { |     if (killCircle + 2 >= gridSize / 2) { | ||||||
|         pauseRunning(); |         pauseRunning(); | ||||||
|         cout << "STOP" << endl; |         cout << "STOP" << endl; | ||||||
|         glutPostRedisplay(); // update display
 | //        glutPostRedisplay(); // update display
 | ||||||
|         return 1; |         return 1; | ||||||
|     } else return 0; |     } else return 0; | ||||||
| } | } | ||||||
| @ -239,18 +246,20 @@ int DLASystem::checkStick() { | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| // constructor
 | // constructor
 | ||||||
| DLASystem::DLASystem(Window *set_win) { | DLASystem::DLASystem(ofstream out_file) { | ||||||
|     cout << "creating system, gridSize " << gridSize << endl; |     cout << "creating system, gridSize " << gridSize << endl; | ||||||
|     win = set_win; |  | ||||||
|     numParticles = 0; |     numParticles = 0; | ||||||
|     endNum = 1000; |     endNum = 1000; | ||||||
|  |     csv_out = std::move(out_file); | ||||||
| 
 | 
 | ||||||
|     // allocate memory for the grid, remember to free the memory in destructor
 |     // allocate memory for the grid, remember to free the memory in destructor
 | ||||||
|     grid = new int *[gridSize]; |     grid = new int *[gridSize]; | ||||||
|     for (int i = 0; i < gridSize; i++) { |     for (int i = 0; i < gridSize; i++) { | ||||||
|         grid[i] = new int[gridSize]; |         grid[i] = new int[gridSize]; | ||||||
|     } |     } | ||||||
|     slowNotFast = 1; |     slowNotFast = 0; | ||||||
|  |     running = true; | ||||||
|  | 
 | ||||||
|     // reset initial parameters
 |     // reset initial parameters
 | ||||||
|     Reset(); |     Reset(); | ||||||
| 
 | 
 | ||||||
| @ -272,45 +281,7 @@ DLASystem::~DLASystem() { | |||||||
|         delete[] grid[i]; |         delete[] grid[i]; | ||||||
|     delete[] grid; |     delete[] grid; | ||||||
| 
 | 
 | ||||||
|     if (logfile.is_open()) |     if (this->csv_out.is_open()) { | ||||||
|         logfile.close(); |         this->csv_out.close(); | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| // this draws the system
 |  | ||||||
| void DLASystem::DrawSquares() { |  | ||||||
| 
 |  | ||||||
|     // draw the particles
 |  | ||||||
|     double halfSize = 0.5; |  | ||||||
|     for (int p = 0; p < numParticles; p++) { |  | ||||||
|         double *vec = particleList[p]->pos; |  | ||||||
|         glPushMatrix(); |  | ||||||
|         if (p == numParticles - 1 && lastParticleIsActive == 1) |  | ||||||
|             glColor4fv(colours::red); |  | ||||||
|         else if (p == 0) |  | ||||||
|             glColor4fv(colours::green); |  | ||||||
|         else |  | ||||||
|             glColor4fv(colours::blue); |  | ||||||
|         glRectd(drawScale * (vec[0] - halfSize), |  | ||||||
|                 drawScale * (vec[1] - halfSize), |  | ||||||
|                 drawScale * (vec[0] + halfSize), |  | ||||||
|                 drawScale * (vec[1] + halfSize)); |  | ||||||
|         glPopMatrix(); |  | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
|     // print some information (at top left)
 |  | ||||||
|     // this ostringstream is a way to create a string with numbers and words (similar to cout << ... )
 |  | ||||||
|     ostringstream str; |  | ||||||
|     str << "num " << numParticles << " size " << clusterRadius; |  | ||||||
| 
 |  | ||||||
|     // print the string
 |  | ||||||
|     win->displayString(str, -0.9, 0.9, colours::red); |  | ||||||
| 
 |  | ||||||
|     // if we are paused then print this (at bottom left)
 |  | ||||||
|     if (running == 0) { |  | ||||||
|         ostringstream pauseStr; |  | ||||||
|         pauseStr << "paused"; |  | ||||||
|         win->displayString(pauseStr, -0.9, -0.9, colours::red); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										21
									
								
								DLASystem.h
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								DLASystem.h
									
									
									
									
									
								
							| @ -1,6 +1,5 @@ | |||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include <GLUT/glut.h> |  | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <fstream> | #include <fstream> | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| @ -13,7 +12,6 @@ | |||||||
| #include <string> | #include <string> | ||||||
| #include <sstream> | #include <sstream> | ||||||
| 
 | 
 | ||||||
| #include "Window.h" |  | ||||||
| #include "Particle.h" | #include "Particle.h" | ||||||
| #include "rnd.h" | #include "rnd.h" | ||||||
| 
 | 
 | ||||||
| @ -21,11 +19,7 @@ using namespace std; | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class DLASystem { | class DLASystem { | ||||||
| private: | public: | ||||||
|     // these are private variables and functions that the user will not see
 |  | ||||||
| 
 |  | ||||||
|     Window *win;  // window in which the system is running
 |  | ||||||
| 
 |  | ||||||
|     // list of particles
 |     // list of particles
 | ||||||
|     vector<Particle *> particleList; |     vector<Particle *> particleList; | ||||||
|     int numParticles; |     int numParticles; | ||||||
| @ -39,6 +33,8 @@ private: | |||||||
|     double addCircle; |     double addCircle; | ||||||
|     double killCircle; |     double killCircle; | ||||||
| 
 | 
 | ||||||
|  |     ofstream csv_out; | ||||||
|  | 
 | ||||||
|     // size of grid
 |     // size of grid
 | ||||||
|     static const int gridSize = 1600; |     static const int gridSize = 1600; | ||||||
|     int **grid;  // this will be a 2d array that stores whether each site is occupied
 |     int **grid;  // this will be a 2d array that stores whether each site is occupied
 | ||||||
| @ -67,7 +63,7 @@ public: | |||||||
| 
 | 
 | ||||||
|     // update the system: if there is an active particle then move it,
 |     // update the system: if there is an active particle then move it,
 | ||||||
|     // else create a new particle (on the adding circle)
 |     // else create a new particle (on the adding circle)
 | ||||||
|     void Update(); |     bool Update(); | ||||||
| 
 | 
 | ||||||
|     // draw particles as squares
 |     // draw particles as squares
 | ||||||
|     void DrawSquares(); |     void DrawSquares(); | ||||||
| @ -82,7 +78,7 @@ public: | |||||||
|     int lastParticleIsActive; |     int lastParticleIsActive; | ||||||
| 
 | 
 | ||||||
|     // constructor
 |     // constructor
 | ||||||
|     DLASystem(Window *set_win); |     DLASystem(ofstream output); | ||||||
| 
 | 
 | ||||||
|     // destructor
 |     // destructor
 | ||||||
|     ~DLASystem(); |     ~DLASystem(); | ||||||
| @ -158,11 +154,4 @@ public: | |||||||
|     // check whether the last particle should stick
 |     // check whether the last particle should stick
 | ||||||
|     // currently it sticks whenever it touches another particle
 |     // currently it sticks whenever it touches another particle
 | ||||||
|     int checkStick(); |     int checkStick(); | ||||||
| 
 |  | ||||||
|     // set the background colour for the window
 |  | ||||||
|     // it would be better for an OOP philosophy to make these member functions for the Window class
 |  | ||||||
|     // but we are being a bit lazy here
 |  | ||||||
|     void setWinBackgroundWhite() { glClearColor(1.0, 1.0, 1.0, 1.0); } |  | ||||||
| 
 |  | ||||||
|     void setWinBackgroundBlack() { glClearColor(0.0, 0.0, 0.0, 0.0); } |  | ||||||
| }; | }; | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Makefile
									
									
									
									
									
								
							| @ -10,7 +10,7 @@ | |||||||
| 
 | 
 | ||||||
| CXX     = clang++ | CXX     = clang++ | ||||||
| 
 | 
 | ||||||
| CXXFLAGS = -Wall -Wextra -g -O0  | CXXFLAGS = -Wall -Wextra -g -O0 -std=c++20 -stdlib=libc++ | ||||||
| 
 | 
 | ||||||
| IFLAGS = -I/usr/local/include -I/usr/include | IFLAGS = -I/usr/local/include -I/usr/include | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										27
									
								
								Window.cpp
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								Window.cpp
									
									
									
									
									
								
							| @ -1,27 +0,0 @@ | |||||||
| #include "Window.h" |  | ||||||
| 
 |  | ||||||
| // constructor
 |  | ||||||
| Window::Window(int set_size[], string &set_title) { |  | ||||||
|     size[0] = set_size[0]; |  | ||||||
|     size[1] = set_size[1]; |  | ||||||
|     title = set_title; |  | ||||||
| 
 |  | ||||||
|     locateOnScreen(); |  | ||||||
|     glutInitWindowSize(size[0], size[1]); |  | ||||||
|     glutInitWindowPosition(pos[0], pos[1]); |  | ||||||
|     glutInitDisplayMode(GLUT_RGBA | GLUT_DOUBLE); |  | ||||||
|     glutCreateWindow(title.c_str()); |  | ||||||
| 
 |  | ||||||
|     // sets the background to black
 |  | ||||||
|     glClearColor(0.0, 0.0, 0.0, 0.0); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // print a string at a given position, don't worry about how this works...
 |  | ||||||
| void Window::displayString(ostringstream &str, double x, double y, GLfloat col[]) { |  | ||||||
|     string localString = str.str(); |  | ||||||
|     glColor4fv(col); |  | ||||||
|     glRasterPos2d(x, y); |  | ||||||
|     for (int i = 0; i < localString.length(); i++) { |  | ||||||
|         glutBitmapCharacter(GLUT_BITMAP_8_BY_13, localString[i]); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
							
								
								
									
										34
									
								
								Window.h
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								Window.h
									
									
									
									
									
								
							| @ -1,34 +0,0 @@ | |||||||
| #pragma once |  | ||||||
| 
 |  | ||||||
| #include <GLUT/glut.h> |  | ||||||
| #include <iostream> |  | ||||||
| #include <string> |  | ||||||
| #include <sstream> |  | ||||||
| 
 |  | ||||||
| using namespace std; |  | ||||||
| 
 |  | ||||||
| class Window { |  | ||||||
| public: |  | ||||||
|     string title; |  | ||||||
|     int size[2]; |  | ||||||
|     int pos[2]; |  | ||||||
| 
 |  | ||||||
|     void locateOnScreen() { |  | ||||||
|         // the fx sets where on the screen the window will appear
 |  | ||||||
|         // (values should be between 0 and 1)
 |  | ||||||
|         double fx[] = {0.7, 0.5}; |  | ||||||
|         pos[0] = (glutGet(GLUT_SCREEN_WIDTH) - size[0]) * fx[0]; |  | ||||||
|         pos[1] = (glutGet(GLUT_SCREEN_HEIGHT) - size[1]) * fx[1]; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // constructor, size is in pixels
 |  | ||||||
|     Window(int set_size[], string &set_title); |  | ||||||
| 
 |  | ||||||
|     // function which prints a string to the screen, at a given position, with a given color
 |  | ||||||
|     // note position is "absolute", not easy to get two strings spaced one above each other like this
 |  | ||||||
|     void displayString(ostringstream &str, double x, double y, GLfloat col[]); |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
							
								
								
									
										2087
									
								
								example.csv
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2087
									
								
								example.csv
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										149
									
								
								mainDLA.cpp
									
									
									
									
									
								
							
							
						
						
									
										149
									
								
								mainDLA.cpp
									
									
									
									
									
								
							| @ -1,12 +1,7 @@ | |||||||
| #include <GLUT/glut.h> |  | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <stdio.h> |  | ||||||
| #include <vector> | #include <vector> | ||||||
| #include <math.h> |  | ||||||
| #include <string> |  | ||||||
| 
 | 
 | ||||||
| #include "DLASystem.h" | #include "DLASystem.h" | ||||||
| #include "Window.h" |  | ||||||
| 
 | 
 | ||||||
| using namespace std; | using namespace std; | ||||||
| 
 | 
 | ||||||
| @ -25,148 +20,24 @@ namespace drawFuncs { | |||||||
| DLASystem *sys; | DLASystem *sys; | ||||||
| 
 | 
 | ||||||
| int main(int argc, char **argv) { | int main(int argc, char **argv) { | ||||||
|     // turn on glut
 |     const auto seed = std::stoi(argv[1]); | ||||||
|     glutInit(&argc, argv); |     char buffer[20]; | ||||||
| 
 |     snprintf(buffer, 20, "seed-%i.csv", seed); | ||||||
|     int window_size[] = {480, 480}; |     const auto p1 = std::chrono::system_clock::now(); | ||||||
|     string window_title("simple DLA simulation"); |     std::ofstream myfile; | ||||||
| 
 |     myfile.open(buffer); | ||||||
|     // create a window
 |  | ||||||
|     Window *win = new Window(window_size, window_title); |  | ||||||
| 
 | 
 | ||||||
|     // create the system
 |     // create the system
 | ||||||
|     sys = new DLASystem(win); |     sys = new DLASystem(std::move(myfile)); | ||||||
| 
 | 
 | ||||||
|     // this is the seed for the random numbers
 |     // this is the seed for the random numbers
 | ||||||
|     int seed = 6; |  | ||||||
|     cout << "setting seed " << seed << endl; |     cout << "setting seed " << seed << endl; | ||||||
|     sys->setSeed(seed); |     sys->setSeed(seed); | ||||||
| 
 | 
 | ||||||
|     // print the "help" message to the console
 |     while (sys->Update()) { | ||||||
|     drawFuncs::introMessage(); |     } | ||||||
| 
 | 
 | ||||||
|     // tell openGL how to redraw the screen and respond to the keyboard
 |     cout << sys->numParticles; | ||||||
|     glutDisplayFunc(drawFuncs::display); |  | ||||||
|     glutKeyboardFunc(drawFuncs::handleKeypress); |  | ||||||
| 
 |  | ||||||
|     // tell openGL to do its first update after waiting 10ms
 |  | ||||||
|     int wait = 10; |  | ||||||
|     int val = 0; |  | ||||||
|     glutTimerFunc(wait, drawFuncs::update, val); |  | ||||||
| 
 |  | ||||||
|     // start the openGL stuff
 |  | ||||||
|     glutMainLoop(); |  | ||||||
| 
 | 
 | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| 
 |  | ||||||
| // this is just a help message
 |  | ||||||
| void drawFuncs::introMessage() { |  | ||||||
|     cout << "Keys (while in graphics window):" << endl << "  q or e to quit (or exit)" << endl; |  | ||||||
|     cout << "  h to print this message (help)" << endl; |  | ||||||
|     cout << "  u for a single update" << endl; |  | ||||||
|     cout << "  g to start running (go)" << endl; |  | ||||||
|     cout << "  p to pause running" << endl; |  | ||||||
|     cout << "  s to run in slow-mode" << endl; |  | ||||||
|     cout << "  f to run in fast-mode" << endl; |  | ||||||
|     cout << "  r to clear everything (reset)" << endl; |  | ||||||
|     cout << "  z to pause and zoom in" << endl; |  | ||||||
|     cout << "  w or b to change background colour to white or black" << endl; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // openGL function deals with the keyboard
 |  | ||||||
| void drawFuncs::handleKeypress(unsigned char key, int x, int y) { |  | ||||||
|     switch (key) { |  | ||||||
|         case 'h': |  | ||||||
|             drawFuncs::introMessage(); |  | ||||||
|             break; |  | ||||||
|         case 'q': |  | ||||||
|         case 'e': |  | ||||||
|             cout << "Exiting..." << endl; |  | ||||||
|             // delete the system
 |  | ||||||
|             delete sys; |  | ||||||
|             exit(0); |  | ||||||
|             break; |  | ||||||
|         case 'p': |  | ||||||
|             cout << "pause" << endl; |  | ||||||
|             sys->pauseRunning(); |  | ||||||
|             break; |  | ||||||
|         case 'g': |  | ||||||
|             cout << "go" << endl; |  | ||||||
|             sys->setRunning(); |  | ||||||
|             glutTimerFunc(0, drawFuncs::update, 0); |  | ||||||
|             break; |  | ||||||
|         case 's': |  | ||||||
|             cout << "slow" << endl; |  | ||||||
|             sys->setSlow(); |  | ||||||
|             break; |  | ||||||
|         case 'w': |  | ||||||
|             cout << "white" << endl; |  | ||||||
|             sys->setWinBackgroundWhite(); |  | ||||||
|             break; |  | ||||||
|         case 'b': |  | ||||||
|             cout << "black" << endl; |  | ||||||
|             sys->setWinBackgroundBlack(); |  | ||||||
|             break; |  | ||||||
|         case 'f': |  | ||||||
|             cout << "fast" << endl; |  | ||||||
|             sys->setFast(); |  | ||||||
|             break; |  | ||||||
|         case 'r': |  | ||||||
|             cout << "reset" << endl; |  | ||||||
|             sys->Reset(); |  | ||||||
|             break; |  | ||||||
|         case 'z': |  | ||||||
|             cout << "zoom" << endl; |  | ||||||
|             sys->pauseRunning(); |  | ||||||
|             sys->viewAddCircle(); |  | ||||||
|             break; |  | ||||||
|         case 'u': |  | ||||||
|             cout << "upd" << endl; |  | ||||||
|             sys->Update(); |  | ||||||
|             break; |  | ||||||
|     } |  | ||||||
|     // tell openGL to redraw the window
 |  | ||||||
|     glutPostRedisplay(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // this function gets called whenever the algorithm should do its update
 |  | ||||||
| void drawFuncs::update(int val) { |  | ||||||
|     int wait;  // time to wait between updates (milliseconds)
 |  | ||||||
| 
 |  | ||||||
|     if (sys->running) { |  | ||||||
|         if (sys->slowNotFast == 1) |  | ||||||
|             wait = 10; |  | ||||||
|         else |  | ||||||
|             wait = 0; |  | ||||||
| 
 |  | ||||||
|         sys->Update(); |  | ||||||
| 
 |  | ||||||
|         // tell openGL to call this funtion again after "wait" milliseconds
 |  | ||||||
|         glutTimerFunc(wait, drawFuncs::update, 0); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| // this function redraws the window when necessary
 |  | ||||||
| void drawFuncs::display() { |  | ||||||
|     //  Clear the window or more specifically the frame buffer...
 |  | ||||||
|     //  This happens by replacing all the contents of the frame
 |  | ||||||
|     //  buffer by the clear color (black in our case)
 |  | ||||||
|     glClear(GL_COLOR_BUFFER_BIT); |  | ||||||
| 
 |  | ||||||
|     // this puts the camera at the origin (not sure why) with (I think) z axis out of page and y axis up
 |  | ||||||
|     // there is also the question of the GL perspective which is not set up in any clear way at the moment
 |  | ||||||
|     glMatrixMode(GL_MODELVIEW); |  | ||||||
|     glLoadIdentity(); |  | ||||||
|     gluLookAt(0.0, 0.0, 1.0,   /* camera position */ |  | ||||||
|               0.0, 0.0, -1.0,        /* point to look at */ |  | ||||||
|               0.0, 1.0, 0.0);           /* up direction */ |  | ||||||
| 
 |  | ||||||
|     //sys->DrawSpheres();
 |  | ||||||
|     sys->DrawSquares(); |  | ||||||
| 
 |  | ||||||
|     //  Swap contents of backward and forward frame buffers
 |  | ||||||
|     glutSwapBuffers(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
|  | |||||||
							
								
								
									
										2087
									
								
								seed-2.csv
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2087
									
								
								seed-2.csv
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user