readFile() implemented
This commit is contained in:
		| @@ -10,6 +10,11 @@ add_executable(Informatikprojekt cpuMain.c ${PROJECT_SOURCES_OPENGL}) | |||||||
| add_executable(Informatikprojekt_OpenGL openglMain.c ${PROJECT_SOURCES_OPENGL}) | add_executable(Informatikprojekt_OpenGL openglMain.c ${PROJECT_SOURCES_OPENGL}) | ||||||
| add_executable(Informatikprojekt_Vulkan vulkanMain.c ${PROJECT_SOURCES_VULKAN}) | add_executable(Informatikprojekt_Vulkan vulkanMain.c ${PROJECT_SOURCES_VULKAN}) | ||||||
|  |  | ||||||
|  | # Copy shader file to output directory | ||||||
|  | configure_file(./shaders/opengl/ComputeShader.glsl ComputeShader.glsl COPYONLY) | ||||||
|  | configure_file(./shaders/opengl/VertexShader.glsl VertexShader.glsl COPYONLY) | ||||||
|  | configure_file(./shaders/opengl/FragmentShader.glsl FragmentShader.glsl COPYONLY) | ||||||
|  |  | ||||||
| # Vulkan | # Vulkan | ||||||
| find_package(Vulkan REQUIRED) | find_package(Vulkan REQUIRED) | ||||||
| target_include_directories(${PROJECT_NAME} PUBLIC ${Vulkan_INCLUDE_DIRS}) | target_include_directories(${PROJECT_NAME} PUBLIC ${Vulkan_INCLUDE_DIRS}) | ||||||
|   | |||||||
							
								
								
									
										114
									
								
								openglMain.c
									
									
									
									
									
								
							
							
						
						
									
										114
									
								
								openglMain.c
									
									
									
									
									
								
							| @@ -29,117 +29,9 @@ int main() | |||||||
|     initRandomParticles(e1); |     initRandomParticles(e1); | ||||||
|  |  | ||||||
|     /************* SHADER *************/ |     /************* SHADER *************/ | ||||||
|     const GLchar *computeShaderSource = "#version 460\n" |     const GLchar *computeShaderSource = readFile("ComputeShader.glsl"); | ||||||
|                                         "\n" |     const GLchar *vertexShaderSource = readFile("VertexShader.glsl"); | ||||||
|                                         "#define FLOAT_MAX 4294967296.0f\n" |     const GLchar *fragmentShaderSource = readFile("FragmentShader.glsl"); | ||||||
|                                         "#define FLOAT_FACTOR 0.00000000023283064365386962890625f\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "struct particle\n" |  | ||||||
|                                         "{\n" |  | ||||||
|                                         "    float px, py, pz;\n" |  | ||||||
|                                         "    float vx, vy, vz;\n" |  | ||||||
|                                         "    float cx, cy, cz;\n" |  | ||||||
|                                         "    float age;\n" |  | ||||||
|                                         "};\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "layout(std430, binding = 0) buffer particles\n" |  | ||||||
|                                         "{\n" |  | ||||||
|                                         "    particle p[];\n" |  | ||||||
|                                         "};\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "layout(location = 0) uniform float dt;\n" |  | ||||||
|                                         "layout(location = 1) uniform vec3 resetPos;\n" |  | ||||||
|                                         "layout(location = 2) uniform uint maxParticles;\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "layout (local_size_x = 256, local_size_y = 1, local_size_z = 1) in;\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "uint hash(uvec3 seed)\n" |  | ||||||
|                                         "{\n" |  | ||||||
|                                         "    uint hash;\n" |  | ||||||
|                                         "    hash = (seed.x ^ 61u) ^ (seed.y >> 16u);\n" |  | ||||||
|                                         "    hash *= 9u;\n" |  | ||||||
|                                         "    hash = seed.z ^ (seed.x >> 4u);\n" |  | ||||||
|                                         "    hash *= 0x27d4eb2du;\n" |  | ||||||
|                                         "    hash = seed.y ^ (seed.z >> 15u);\n" |  | ||||||
|                                         "    return hash;\n" |  | ||||||
|                                         "}\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "uint rand(uint seed)\n" |  | ||||||
|                                         "{\n" |  | ||||||
|                                         "    seed ^= (seed << 13u);\n" |  | ||||||
|                                         "    seed ^= (seed >> 17u);\n" |  | ||||||
|                                         "    seed ^= (seed << 5u);\n" |  | ||||||
|                                         "    return seed;\n" |  | ||||||
|                                         "}\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "int foreSign(uint seed)\n" |  | ||||||
|                                         "{\n" |  | ||||||
|                                         "    return rand(seed) % 2 == 0 ? 1 : -1;\n" |  | ||||||
|                                         "}\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "void main()\n" |  | ||||||
|                                         "{\n" |  | ||||||
|                                         "    uint gid = gl_GlobalInvocationID.x;\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "    if (gid <= maxParticles)\n" |  | ||||||
|                                         "    {\n" |  | ||||||
|                                         "        particle part = p[gid];\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "        uint hash1 = hash(uvec3(uint(part.px * FLOAT_MAX), uint(part.cy * FLOAT_MAX), uint(part.vz * FLOAT_MAX)));\n" |  | ||||||
|                                         "        uint hash2 = hash(uvec3(uint(part.vx * FLOAT_MAX), uint(part.py * FLOAT_MAX), uint(part.cz * FLOAT_MAX)));\n" |  | ||||||
|                                         "        uint hash3 = hash(uvec3(uint(part.cx * FLOAT_MAX), uint(part.vy * FLOAT_MAX), uint(part.pz * FLOAT_MAX)));\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "        if (part.age < 0 || part.px > 1 || part.py > 1 || part.pz > 1 || part.px < -1 || part.py < -1 || part.pz < -1)\n" |  | ||||||
|                                         "        {\n" |  | ||||||
|                                         "            part.px = resetPos.x;\n" |  | ||||||
|                                         "            part.py = resetPos.y;\n" |  | ||||||
|                                         "            part.pz = resetPos.z;\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "            part.age = rand(hash(uvec3(hash1, hash2, hash3))) % (250 - 60 + 1) + 60;\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "            part.vx = foreSign(hash1) * float(rand(hash2)) * FLOAT_FACTOR;\n" |  | ||||||
|                                         "            part.vy = foreSign(hash3) * float(rand(hash1)) * FLOAT_FACTOR;\n" |  | ||||||
|                                         "            part.vz = foreSign(hash2) * float(rand(hash3)) * FLOAT_FACTOR;\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "            part.cx = float(rand(hash1 ^ hash2)) * FLOAT_FACTOR;\n" |  | ||||||
|                                         "            part.cy = float(rand(hash2 ^ hash3)) * FLOAT_FACTOR;\n" |  | ||||||
|                                         "            part.cz = float(rand(hash3 ^ hash1)) * FLOAT_FACTOR;\n" |  | ||||||
|                                         "        }\n" |  | ||||||
|                                         "        else\n" |  | ||||||
|                                         "        {\n" |  | ||||||
|                                         "            part.px += part.vx * dt;\n" |  | ||||||
|                                         "            part.py += part.vy * dt;\n" |  | ||||||
|                                         "            part.pz += part.vz * dt;\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "            part.age -= 0.01f;\n" |  | ||||||
|                                         "        }\n" |  | ||||||
|                                         "\n" |  | ||||||
|                                         "        p[gid] = part;\n" |  | ||||||
|                                         "    }\n" |  | ||||||
|                                         "}"; |  | ||||||
|  |  | ||||||
|     const GLchar *vertexShaderSource = "#version 460\n" |  | ||||||
|                                        "\n" |  | ||||||
|                                        "layout(location = 0) in vec3 pos;\n" |  | ||||||
|                                        "layout(location = 1) in vec3 colIn;\n" |  | ||||||
|                                        "\n" |  | ||||||
|                                        "layout(location = 0) out vec3 colV;\n" |  | ||||||
|                                        "\n" |  | ||||||
|                                        "void main(void)\n" |  | ||||||
|                                        "{\n" |  | ||||||
|                                        "    colV = colIn;\n" |  | ||||||
|                                        "    gl_Position = vec4(pos, 1);\n" |  | ||||||
|                                        "}"; |  | ||||||
|  |  | ||||||
|     const GLchar *fragmentShaderSource = "#version 460\n" |  | ||||||
|                                          "\n" |  | ||||||
|                                          "layout(location = 0) in vec3 colV;\n" |  | ||||||
|                                          "layout(location = 0) out vec4 colOut;\n" |  | ||||||
|                                          "\n" |  | ||||||
|                                          "void main(void)\n" |  | ||||||
|                                          "{\n" |  | ||||||
|                                          "    colOut = vec4(colV, 1);\n" |  | ||||||
|                                          "}"; |  | ||||||
|  |  | ||||||
|     GLuint computeShader = compileShader(computeShaderSource, GL_COMPUTE_SHADER); |     GLuint computeShader = compileShader(computeShaderSource, GL_COMPUTE_SHADER); | ||||||
|     GLuint vertexShader = compileShader(vertexShaderSource, GL_VERTEX_SHADER); |     GLuint vertexShader = compileShader(vertexShaderSource, GL_VERTEX_SHADER); | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								shaders/opengl/FragmentShader.glsl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								shaders/opengl/FragmentShader.glsl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,9 @@ | |||||||
|  | #version 460 | ||||||
|  |  | ||||||
|  | layout(location = 0) in vec3 colV; | ||||||
|  | layout(location = 0) out vec4 colOut; | ||||||
|  |  | ||||||
|  | void main(void) | ||||||
|  | { | ||||||
|  |     colOut = vec4(colV, 1); | ||||||
|  | } | ||||||
							
								
								
									
										28
									
								
								utils.c
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								utils.c
									
									
									
									
									
								
							| @@ -1,27 +1,33 @@ | |||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <malloc.h> | #include <malloc.h> | ||||||
|  | #include <errno.h> | ||||||
|  | #include <string.h> | ||||||
| #include "utils.h" | #include "utils.h" | ||||||
|  |  | ||||||
| #define BUFFER_SIZE 1024 | #define BUFFER_SIZE 1024 | ||||||
|  |  | ||||||
| char *readFile(char *path) | char *readFile(char *filename) | ||||||
| { | { | ||||||
|     FILE *file = fopen(path, "r"); |     FILE    *file; | ||||||
|     char *str = malloc(BUFFER_SIZE); |     char    *buffer; | ||||||
|     int c, i = 0, j = 1; |     long    numbytes; | ||||||
|  |  | ||||||
|     while ((c = fgetc(file)) != EOF) |     if((file = fopen(filename, "r")) == NULL) | ||||||
|     { |     { | ||||||
|         if (i == j * BUFFER_SIZE) |         printf("ERROR open file %s: %s\n", filename, strerror(errno)); | ||||||
|         { |  | ||||||
|             str = realloc(str, ++j * BUFFER_SIZE); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|         str[i++] = (char) c; |     fseek(file, 0L, SEEK_END); | ||||||
|  |     numbytes = ftell(file); | ||||||
|  |     fseek(file, 0L, SEEK_SET); | ||||||
|  |  | ||||||
|  |     if((buffer = calloc(numbytes, sizeof(char))) == NULL) | ||||||
|  |     { | ||||||
|  |         printf("ERROR allocating memory: %s\n", strerror(errno)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     fread(buffer, sizeof(char), numbytes, file); | ||||||
|     fclose(file); |     fclose(file); | ||||||
|  |  | ||||||
|     return str; |     return buffer; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user