Computação Gráfica. GLSL - Programação de Shaders Iluminação
|
|
|
- Diego Taveira Castilhos
- 10 Há anos
- Visualizações:
Transcrição
1 Computação Gráfica GLSL - Programação de Shaders Iluminação António Ramires Fernandes - Computação Gráfica 07/08
2 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional Direcional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 2
3 Tipos de Dados Escalares float float a,b=2.0; int int c,d=1; bool bool e,f= true; Vectores vec{2,3,4} vec3 v = vec3(1,2,3); ivec{2,3,4} vec3 a = v, b = vec3(4); bvec{2,3,4} Matrizes mat{2,3,4} mat3 m = mat3(1.0); // matriz identidade mat3 n = mat3(v,a,b); DI-UM Computação Gráfica 07/08 3
4 Tipos de Dados Selectores para Vectores x,y,z,w r,g,b,a s,t,p,q vec3 v = vec3(1.0,2.0,3.0); float f = v.x; // f = 1.0 float y = v[1]; // y = 2.0 vec3 u = v.zyx // u = (3.0,2.0,1.0) Selectores para Matrizes mat2 m = mat2(1.0); // m = matriz identidade vec2 v = m[0]; // v = (1.0,0.0) primeira coluna float f = m[0][0] // f = 1.0 DI-UM Computação Gráfica 07/08 4
5 Tipos de Dados Estruturas Definição struct luz { vec3 pos; vec3 cor; }; Declaração e inicialização Utilização luz luz1; luz luz2 = luz(vec3(1.0,2.0,3.0),vec3(1.0,0.0,0.0)); luz1.pos = vec3(1.0,2.0,3.0); DI-UM Computação Gráfica 07/08 5
6 Tipos de Dados Arrays vec3 pontos[5]; vec4 vertices[]; No caso de um array não definir a sua dimensão, o compilador procura o índice mais elevado no shader. Neste caso, os índices têm de ser constantes. DI-UM Computação Gráfica 07/08 6
7 Tipos de Dados Casting Realizado através de construtores float a = 3.0; int b = int(a); Constantes const int texturas = 10; DI-UM Computação Gráfica 07/08 7
8 Funções Semelhante ao C vec3 f() {... } Tipos dos parâmetros in out inout vec3 f(in vec3 a, out vec3 b) {... } DI-UM Computação Gráfica 07/08 8
9 Controle de fluxo Instruções iguais a C if else for while do while DI-UM Computação Gráfica 07/08 9
10 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional Direcional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 10
11 GLSL - Minimal - Vértices A funcionalidade fixa, ff, determina que um vértice deve ser transformado através da seguinte operação: Vres = Matriz PROJECTION * Matriz MODELVIEW * vertex O vertex shader recebe os vértices através da variável: attribute vec4 gl_vertex: O vertex shader deve transformar o vértice recebido e escrever o resultado em: vec4 gl_position; Variáveis de estado do OpenGL acessiveis: uniform mat4 gl_modelviewmatrix; uniform mat4 gl_projectionmatrix; uniform mat4 gl_modelviewprojectionmatrix; DI-UM Computação Gráfica 07/08 11
12 GLSL - Minimal - Vértices Para obter uma funcionalidade semelhante à ff, o vertex shader deverá então calcular gl_position utilizando uma das seguintes opções: gl_position = gl_projectionmatrix * (gl_modelviewmatrix * gl_vertex); gl_position = gl_modelviewprojectionmatrix * gl_vertex; gl_position = ftransform(); Esta última alternativa garante a funcionalidade exacta da ff. DI-UM Computação Gráfica 07/08 12
13 GLSL - Minimal - Vértices Vertex Shader void main (void) { } gl_position = ftransform(); DI-UM Computação Gráfica 07/08 13
14 GLSL - Minimal - Cor Constante O Fragment shader é responsável por escrever a variável gl_fragcolor. void main(void) { } gl_fragcolor = vec4(1,0,0,1); DI-UM Computação Gráfica 07/08 14
15 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional Direcional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 15
16 GLSL - Cores Um vertex shader calcula valores por vértice. Dentro de um Fragment shader precisamos de ter acesso aos valores interpolados para realizar os cálculos para cada fragmento. O pipeline gráfico utiliza os valores processados para cada vértice no vertex shader, e interpola-os de acordo com a construção de primitivas (utilizando a informação de conectividade). Estas variáveis interpoladas têm o qualificador varying. DI-UM Computação Gráfica 07/08 16
17 GLSL - Cores Código OpenGL glbegin(gl_quads); glcolor3f(1,0,0); glvertex3f(-1,-1,0); glcolor3f(0,1,0); glvertex3f(1,-1,0); glcolor3f(0,0,1); glvertex3f(1,1,0); glcolor3f(1,1,0); glvertex3f(-1,1,0); glend(); DI-UM Computação Gráfica 07/08 17
18 GLSL - Cores Variáveis de estado acessíveis nos shaders: attribute vec4 gl_color; // só vertex shader struct gl_materialparameters { vec4 emission; // Ecm vec4 ambient; // Acm vec4 diffuse; // Dcm vec4 specular; // Scm float shininess; // Srm }; uniform gl_materialparameters gl_frontmaterial; uniform gl_materialparameters gl_backmaterial; DI-UM Computação Gráfica 07/08 18
19 GLSL - Cores Vertex Shader obtem cor especificada na aplicação (glcolor) em: attribute vec4 gl_color; Vertex Shader escreve em: varying vec4 gl_frontcolor; varying vec4 gl_backcolor; Fragment Shader lê cor interpolada em: varying vec4 gl_color; Nota: não é a mesma variável que está acessível no vertex shader. Esta variável é interpolada pelo OpenGL a partir das variáveis gl_frontcolor e gl_backcolor. Fragment Shader escreve em: vec4 gl_fragcolor DI-UM Computação Gráfica 07/08 19
20 GLSL - Cores Exemplo // Aplicação OpenGL glbegin(gl_quads); glcolor3f(1,0,0); glvertex3f(-1,-1,0); glcolor3f(0,1,0); glvertex3f(1,-1,0); glcolor3f(0,0,1); glvertex3f(1,1,0); glcolor3f(1,1,0); glvertex3f(-1,1,0); glend(); // Vertex Shader void main(void) { } gl_frontcolor = gl_color; gl_position = ftransform(); // Fragment Shader void main() { gl_fragcolor = gl_color; } DI-UM Computação Gráfica 07/08 20
21 GLSL - Cores Exemplo // Aplicação OpenGL glmaterialfv(gl_front, GL_AMBIENT, bluematerial); glbegin(gl_quads); glcolor3f(1,0,0); glvertex3f(-1,-1,0); glcolor3f(0,1,0); glvertex3f(1,-1,0); glcolor3f(0,0,1); glvertex3f(1,1,0); glcolor3f(1,1,0); glvertex3f(-1,1,0); glend(); // Vertex Shader void main(void) { } gl_frontcolor = gl_frontmaterial.ambient; gl_position = ftransform(); // Fragment Shader void main() { gl_fragcolor = gl_color; } DI-UM Computação Gráfica 07/08 21
22 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional Direcional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 22
23 GLSL - Iluminação Reflexão difusa (Lambert) A intensidade de um objecto é proporcional ao ângulo entre a direcção da luz e a normal do objecto. Intensidade da luz I = I p * K d * cos (θ) N θ L coeficiente de reflexão difusa DI-UM Computação Gráfica 07/08 23
24 GLSL - Iluminação Adicionando a componente ambiente: I = I a * K a + I p * K d * cos (θ) Caso ambos os vectores estejam normalizados pode-se substituir o coseno pelo produto interno, I = I a * K a + I p * K d * (N. L) Produto Interno N.L = n x * l x + n y * l y + n z * l z Nota: só se consideram valores positivos do produto interno ou coseno DI-UM Computação Gráfica 07/08 24
25 GLSL - Iluminação Código OpenGL: glloadidentity(); glulookat(0.0, 0.0, 5.0, 0.0,0.0,0.0, 0.0,1.0,0.0); gllightfv(gl_light0, GL_POSITION, lightposition); glutsolidteapot(1); A especificação do OpenGL diz que a posição da luz é transformada pela matriz ModelView na altura da sua especificação, ou seja quando um shader acede à posição da luz, está a aceder à posição da luz no espaço da câmara. É necessário transformar as normais para o espaço câmara para poder calcular o coseno do ângulo entre a normal e a direcção da luz. DI-UM Computação Gráfica 07/08 25
26 GLSL - Iluminação Transformação da Normal Caso a matriz ModelView não seja ortogonal, a normal pode ser incorrectamente transformada. T' N' T N N' = MN T' = MT Precisamos de encontrar uma matriz G que transforme N de forma a que N'.T' = 0 (prod. interno) DI-UM Computação Gráfica 07/08 26
27 GLSL - Iluminação Transformação da Normal N'.T' = (GN).(MT) = 0 (GN).(MT) = (GN) T (MT) = N T G T MT Sabemos que N T T = 0, logo a equação é satisfeita quando G T M = I, ou seja G = (M -1 ) T Se M for ortogonal M -1 = M T, logo G = M DI-UM Computação Gráfica 07/08 27
28 GLSL - Iluminação GLSL fornece a matriz G: gl_normalmatrix Sendo assim o cálculo da normal dentro de um vertex shader é realizado através da seguinte operação: vec3 n; n = normalize(gl_normalmatrix * gl_normal); Sendo gl_normal a normal especificada para o vértice na aplicação OpenGL através da função glnormal. A normalização da normal num vertex shader pode ser dispensada caso haja garantia de que ambas as condições se verifiquem: a normal especificada na aplicação OpenGL está normalizada a matriz ModelView é ortogonal, i.e., que só foram aplicadas rotações e translações, mas não escalas. DI-UM Computação Gráfica 07/08 28
29 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direccional Direccional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 29
30 GLSL - Iluminação Direcional Variáveis de estado relevantes struct gl_lightsourceparameters { vec4 ambient; // Acli vec4 diffuse; // Dcli vec4 specular; // Scli vec4 position; // Ppli vec4 halfvector; // Derived: Hi... }; uniform gl_lightsourceparameters gl_lightsource[gl_maxlights]; struct gl_lightmodelparameters { vec4 ambient; // Acs }; uniform gl_lightmodelparameters gl_lightmodel; DI-UM Computação Gráfica 07/08 30
31 GLSL - Iluminação Direcional I = I a * K a + I p * K d * (N. L) void main(){ vec3 normal,lightdir; vec4 diffuse,ambient; float intensity; Vertex Shader } lightdir = normalize(vec3(gl_lightsource[0].position)); normal = normalize(gl_normalmatrix * gl_normal); intensity = max(dot(lightdir,normal),0.0); diffuse = gl_lightsource[0].diffuse * gl_frontmaterial.diffuse; ambient = gl_lightsource[0].ambient * gl_frontmaterial.ambient; gl_frontcolor = ambient + diffuse*intensity; gl_position = ftransform(); Fragment Shader void main(){ } gl_fragcolor = gl_color; DI-UM Computação Gráfica 07/08 31
32 GLSL - Iluminação Direcional Incorporar o termo ambiente global e emissivo I = I a * K a + I p * K d * (N. L) + K e + G a * K void main(){ }... gl_frontcolor = ambient + diffuse*intensity; gl_frontcolor += gl_frontmaterial.ambient * gl_lightmodel.ambient; gl_frontcolor += gl_frontmaterial.emissive; gl_position = ftransform(); DI-UM Computação Gráfica 07/08 32
33 GLSL - Iluminação Direcional Incorporar o termo especular Especular = I s * K s * (R.Câmara) s Especular = I s * K s * (H.N) s R N L H N L Câmara α θ θ Câmara θ θ DI-UM Computação Gráfica 07/08 33
34 GLSL - Iluminação Direcional Termo Especular no Vertex Shader Especular = I s * K s * (H.N) s if (intensity > 0) { aux = max(dot(vec3(gl_lightsource[0].halfvector),normal),0.0); shininess = pow(aux,gl_frontmaterial.shininess); specular = gl_lightsource[0].specular * gl_frontmaterial.specular; specular *= shininess; gl_frontcolor += specular; } DI-UM Computação Gráfica 07/08 34
35 GLSL - Iluminação Direcional void main(){ vec3 normal,lightdir; vec4 diffuse,ambient,specular; float intensity, shininess,aux; Vertex Shader lightdir = normalize(vec3(gl_lightsource[0].position)); normal = normalize(gl_normalmatrix * gl_normal); intensity = max(dot(lightdir,normal),0.0); diffuse = gl_lightsource[0].diffuse * gl_frontmaterial.diffuse; ambient = gl_lightsource[0].ambient * gl_frontmaterial.ambient; gl_frontcolor = ambient + diffuse*intensity; gl_frontcolor += gl_frontmaterial.ambient * gl_lightmodel.ambient; gl_frontcolor += gl_frontmaterial.emission; } if (intensity > 0.0) { aux = max(dot(vec3(gl_lightsource[0].halfvector),normal),0.0); shininess = pow(aux,gl_frontmaterial.shininess); specular = gl_lightsource[0].specular * gl_frontmaterial.specular; specular *= shininess; gl_frontcolor += specular; } gl_position = ftransform(); DI-UM Computação Gráfica 07/08 35
36 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional Direcional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 36
37 GLSL - Iluminação Direcional Shaders Apresentados: Vertex Shader calcula cores baseado na iluminação por vértice Fragment Shader utiliza os valores interpolados das cores para cada vértice Passo Seguinte: Cor calculada por pixel DI-UM Computação Gráfica 07/08 37
38 GLSL - Iluminação Direcional Para calcular a cor da superfície iluminada por pixel precisamos para cada ponto da superfície (não só para os vértices) : Normal Vector com direcção do "olhar" Direcção da luz Estes valores podem ser calculados por vértice e passados ao fragment shader que acederá à interpolação dos valores para cada primitiva. DI-UM Computação Gráfica 07/08 38
39 GLSL - Iluminação Direcional A comunicação entre o vertex shader e o fragment shader realiza-se através de duas formas: variáveis pré-definidas (caso das cores); variáveis definidas nos shaders pelo programador e declaradas como varying. DI-UM Computação Gráfica 07/08 39
40 GLSL - Iluminação Direcional Vertex Shader varying vec3 normal, lightdir, ecpos; Variáveis para interpolação void main() { lightdir = normalize(vec3(gl_lightsource[0].position)); normal = normalize(gl_normalmatrix * gl_normal); ecpos = vec3(gl_modelviewmatrix * gl_vertex) ; } gl_position = ftransform(); Porque não normalizar a normal somente no Fragment Shader? O vector com a direcção do olhar é calculado transformando o vértice para o espaço câmara. Neste espaço a câmara encontra-se na origem, e portanto o vector é gl_vertex - campos = gl_vertex. DI-UM Computação Gráfica 07/08 40
41 GLSL - Iluminação Direcional Fragment Shader varying vec3 normal, lightdir, ecpos; void main() { vec4 diffuse,ambient,specular,color; float intensity,shininess; vec3 n,hv,ec; Porquê normalizar novamente? Porque não normalizar a direcção da luz? n = normalize(normal); intensity = max(dot(lightdir,n),0.0);... DI-UM Computação Gráfica 07/08 41
42 GLSL - Iluminação Direcional Fragment Shader (2)... diffuse = gl_lightsource[0].diffuse * gl_frontmaterial.diffuse; ambient = gl_lightsource[0].ambient * gl_frontmaterial.ambient; color = ambient + diffuse*intensity; color += gl_frontmaterial.ambient * gl_lightmodel.ambient; color += gl_frontmaterial.emission;... Aqui realiza-se o cálculo da cor com as componentes difusa, ambiente e emissiva. DI-UM Computação Gráfica 07/08 42
43 GLSL - Iluminação Direcional Fragment Shader (3)... if (intensity > 0.0) { ec = normalize(-ecpos); hv = normalize(ec+lightdir); shininess = pow(max(dot(hv,n),0.0),gl_frontmaterial.shininess); specular = shininess * gl_lightsource[0].specular * gl_frontmaterial.specular; color += specular; } } gl_fragcolor = color; É necessário normalizar o vector com a direcção do olhar pela mesma razão que se normalizou o vector normal. DI-UM Computação Gráfica 07/08 43
44 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional Direcional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 44
45 GLSL - Iluminação Posicional A diferença entre a luz direcional e a luz posicional reduz-se aos seguintes termos: Existência de um factor de atenuação Direcção da luz varia por vértice ( e por pixel) DI-UM Computação Gráfica 07/08 45
46 GLSL - Iluminação Posicional Equação OpenGL cor = m 1 fatt = c + c d + c d Amb = m Diff Spec = e + lm a l * l a a + m = max( L N,0)* m max( 0, q a 2 + H N) f att d *( Amb + Diff * l shininess d * ms * ls) + Spec) onde: m representa o material l representa as propriedades da luz f att é o factor de atenuação relativamente à distância da luz ao objecto lm indica as propriedades do modelo de luz (ambiente) L é o vector unitário que aponta do ponto do objecto à posição da luz N é a normal do ponto do objecto H representa o half-vector DI-UM Computação Gráfica 07/08 46
47 GLSL - Iluminação Posicional Vertex Shader (iluminação por pixel) varying vec3 normal, ecpos; void main() { normal = normalize(gl_normalmatrix * gl_normal); ecpos = vec3(gl_modelviewmatrix * gl_vertex) ; } gl_position = ftransform(); O cálculo da direcção da luz passa para o fragment shader pois esta depende da localização do fragmento DI-UM Computação Gráfica 07/08 47
48 GLSL - Iluminação Posicional Fragment Shader Cálculo do factor de atenuação att = 1 c + c d l + c q d 2 Variáveis de estado relevantes struct gl_lightsourceparameters {... float constantattenuation; float linearattenuation; float quadraticattenuation; }; lightdir = vec3(gl_lightsource[0].position)-ecpos; d = length(lightdir); att = 1 / (gl_lightsource[0].constantattenuation + gl_lightsource[0].linearattenuation * d + gl_lightsource[0].quadraticattenuation * d * d); DI-UM Computação Gráfica 07/08 48
49 GLSL - Iluminação Posicional Fragment Shader varying vec3 normal, ecpos; void main() { vec4 diffuse,ambient,specular,color; float intensity,shininess,d,att; vec3 n,hv,ec, lightdir; lightdir = vec3(gl_lightsource[0].position)-ecpos; n = normalize(normal);... DI-UM Computação Gráfica 07/08 49
50 GLSL - Iluminação Posicional Fragment Shader (2) d = length(lightdir); att = max(1.0,1.0 / (gl_lightsource[0].constantattenuation + gl_lightsource[0].linearattenuation * d + gl_lightsource[0].quadraticattenuation * d * d)); diffuse = gl_lightsource[0].diffuse * FrontMaterial.diffuse; ambient = gl_lightsource[0].ambient * gl_frontmaterial.ambient; lightdir = normalize(lightdir) intensity = max(dot(lightdir,n),0.0); color = (ambient + diffuse*intensity) * att; color += gl_frontmaterial.ambient * gl_lightmodel.ambient; color += gl_frontmaterial.emission;... Aqui realiza-se o cálculo da cor com as componentes difusa, ambiente e emissiva, agora com a atenuação a influenciar a componente difusa e ambiente. DI-UM Computação Gráfica 07/08 50
51 GLSL - Iluminação Posicional Fragment Shader (3)... if (intensity > 0.0) { ec = normalize(-ecpos); hv = normalize(ec+lightdir); shininess = pow(max(dot(hv,n),0.0),gl_frontmaterial.shininess); specular = shininess * gl_lightsource[0].specular * gl_frontmaterial.specular; color += specular * att; } } gl_fragcolor = color; O cálculo da cor especular também é influenciado pela atenuação. DI-UM Computação Gráfica 07/08 51
52 Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional Direcional por pixel Posicional por pixel Spot Light por pixel DI-UM Computação Gráfica 07/08 52
53 GLSL - Iluminação Spot Light A iluminação com spot lights traz as seguintes novidades: A luz tem uma direcção (para alem da posição) Existe um ângulo que define o cone de luz O vertex shader é igual ao caso da luz posicional! DI-UM Computação Gráfica 07/08 53
54 GLSL - Iluminação Spot Light Equação OpenGL cor = m + lm + m + f * spoteffect *( Amb + Diff Spec) f att Amb = m Diff e a a att + 1 = c + c d + c d a l * l = max( L N,0)* m Spec = max(0, H N) a q 2 spoteffect = max(0, L spotdirection) d * l shininess d * ms * ls) spotexponent DI-UM Computação Gráfica 07/08 54
55 GLSL - Iluminação Spot Light Fragment Shader Cálculo de spoteffect s = max(0, -lightdir. spotdirection) Se (acos(s) > cutoff) spoteffect = 0 senão spoteffect = s exponent Variáveis de estado relevantes struct gl_lightsourceparameters {... vec3 spotdirection; // Sdli float spotexponent; // Srli }; float spotcutoff; // Crli // (range: [0.0,90.0], 180.0) float spotcoscutoff; // Derived: cos(crli) // (range: [1.0,0.0],-1.0)... spotdot = max(0.0,dot(-lightdir,gl_lightsource[0].spotdirection)); if (spotdot < gl_lightsource[0].spotcoscutoff) spotatt = 0.0; else spotatt = pow(spotdot,gl_lightsource[0].spotexponent); DI-UM Computação Gráfica 07/08 55
56 GLSL - Iluminação Spot Light Fragment Shader varying vec3 normal, ecpos; void main() { vec4 diffuse,ambient,specular,color; float intensity,shininess,d,att,spotatt,spotdot; vec3 n,hv,ec,lightdir; lightdir = vec3(gl_lightsource[0].position)-ecpos; n = normalize(normal);... A primeira parte do fragment shader é igual ao caso anterior das luzes posicionais. DI-UM Computação Gráfica 07/08 56
57 GLSL - Iluminação Spot Light Fragment Shader (2) d = length(lightdir); att = max(1.0,1.0 / (gl_lightsource[0].constantattenuation + gl_lightsource[0].linearattenuation * d + gl_lightsource[0].quadraticattenuation * d * d)); lightdir = normalize(lightdir); spotdot = max(0.0,dot(-lightdir,gl_lightsource[0].spotdirection)); if (spotdot < gl_lightsource[0].spotcoscutoff) spotatt = 0.0; else spotatt = pow(spotdot,gl_lightsource[0].spotexponent); att *= spotatt; diffuse = gl_lightsource[0].diffuse * gl_frontmaterial.diffuse; ambient = gl_lightsource[0].ambient * gl_frontmaterial.ambient;... Aqui realiza-se o cálculo da cor com as componentes difusa, ambiente e emissiva, agora com a atenuação a influenciar a componente difusa e ambiente. DI-UM Computação Gráfica 07/08 57
58 GLSL - Iluminação Spot Light Fragment Shader (3)... intensity = max(dot(lightdir,n),0.0); color = (ambient + diffuse*intensity) * att; color += gl_frontmaterial.ambient * gl_lightmodel.ambient; color += gl_frontmaterial.emission; if (intensity > 0.0) { } ec = normalize(-ecpos); hv = normalize(ec+lightdir); shininess = pow(max(dot(hv,n),0.0),gl_frontmaterial.shininess); specular = shininess * gl_lightsource[0].specular * gl_frontmaterial.specular; color += specular * att; } gl_fragcolor = color; O cálculo da cor é idêntico ao caso das points lights, tendo em atenção que o factor de atenuação agora também considera o efeito da spotlight. DI-UM Computação Gráfica 07/08 58
59 GLSL - Iluminação Spot Light Ooops! DI-UM Computação Gráfica 07/08 59
60 GLSL - Iluminação Spot Light Análise das contribuições de luz difusa + ambiente + ambiente global + especular ambiente + ambiente global ambiente global DI-UM Computação Gráfica 07/08 60
61 GLSL - Iluminação Spot Light O problema deve-se à forma como a luz ambiente é aplicada. intensity = max(dot(lightdir,n),0.0); color = (ambient + diffuse*intensity) * att; O valor de att depende de: factor de atenuação relativo à distância da luz ao ponto o ponto estar dentro do cone de luz Pelo código acima vemos que a cor ambiente está a ser aplicada sempre que att não seja zero. Os pontos da parte de trás do teapot estão dentro do cone de luz logo têm uma contribuição da luz ambiente, para alem da luz ambiente global. DI-UM Computação Gráfica 07/08 61
62 GLSL - Iluminação Spot Light Código para eliminar o problema: color = (diffuse*intensity)*att; if ((intensity > 0.0) && (spotatt!= 0)) color += ambient; DI-UM Computação Gráfica 07/08 62
63 Referências OpenGL 2.0 Specification, GLSL Specification, "OpenGL Shading Language", Randi Rost, Addison Wesley DI-UM Computação Gráfica 07/08 63
Computação Gráfica. GLSL - Programação de Shaders Iluminação
Computação Gráfica GLSL - Programação de Shaders Iluminação António nio Ramires Fernandes - Multimédia Resumo Tipos de Dados, Funções e Controle de Fluxo GLSL - Minimal GLSL - Cores GLSL - Iluminação Direcional
Computação Gráfica. GLSL Programação de Shaders
Computação Gráfica GLSL Programação de Shaders António Ramires Fernandes - Computação Gráfica 07/08 GLSL Sumário Evolução do Hardware Gráfico PCs Pipeline Gráfico Fixo Pipeline Gráfico Programável Processador
GLSL Programação de Shaders
Universidade do Minho Mestrado em Informática UCE - Computação Gráfica GLSL Programação de Shaders António Ramires Fernandes GLSL Sumário Evolução do Hardware Gráfico PCs Pipeline Gráfico Fixo Pipeline
OpenGL Shading Language
OpenGL Shading Language Guilherme S. Moura ([email protected]) Saulo A. Pessoa ([email protected]) Vladimir Alves ([email protected]) Felipe Maia O que é? High Level Shading Language para OpenGL Descreve shaders
Computação Gráfica. GLSL - Programação de Shaders Toon Mapping; Texturas
Computação Gráfica GLSL - Programação de Shaders Toon Mapping; Texturas António nio Ramires Fernandes - Multimédia GLSL - Programação de Shaders Resumo Toon Shading Coordenadas de Textura Lattice Stripes
Animação e Visualização Tridimensional
Animação e Visualização Tridimensional Mestrado em Engenharia Informática e de Computadores Alameda º mini-teste 22 de Outubro de 204 O mini-teste tem a duração máxima de 45 minutos, tolerância incluída.
Prof. Fernando V. Paulovich http://www.icmc.usp.br/~paulovic [email protected]. 16 de maio de 2011. SCC0250 - Computação Gráca
Métodos para Rendering de Superfície SCC0250 - Computação Gráca Prof. Fernando V. Paulovich http://www.icmc.usp.br/~paulovic [email protected] Instituto de Ciências Matemáticas e de Computação (ICMC)
Modelos de Iluminação Métodos de surface-rendering
Modelos de Iluminação Métodos de surface-rendering VI / CG 2012/2013 Beatriz Sousa Santos, J. Madeira 1 As imagens realistas obtêm-se : usando projecções perspectivas da cena aplicando efeitos de iluminação
Iluminando o Cenário
Iluminando o Cenário O realismo da cena é reforçada pela iluminação; A iluminação dos objetos cria a ilusão de volume: http://mech.fsv.cvut.cz/~dr/papers/habil/node51.html Fundamentos: Fisicamente: a percepção
Modelos de Iluminação Locais
Modelos de luminação Locais Sistemas Gráficos/ Computação Gráfica e nterfaces 1 Modelos de luminação Locais Os modelos de iluminação expressam as componentes de iluminação que definem a intensidade de
Iluminação e sombreamento
OpenGL Iluminação e sombreamento Sombreamento OpenGL calcula a cor de cada pixel e parte disso depende de qual é a iluminação usada no cenário e de como os objetos no cenário refletem ou absorvem a luz
Modelos de Iluminação e Reflexão
Modelos de Iluminação e Reflexão Edward Angel, Cap. 6 Instituto Superior Técnico Computação Gráfica 2009/2010 1 Na última aula... Recorte 2D Cyrus-Beck Sutherland-Hodgman Recorte 3D Sumário Iluminação
Cap. 7 Coloração (Shading) e Iluminação Global
Cap. 7 Coloração (Shading) e Iluminação Global Engenharia Informática (5385) - 2º ano, 2º semestre Revisão sobre Modelos de Iluminação Dependentes da Luz Modelos dependentes da luz Ambiente Normais à superfície
Paulo Sérgio Rodrigues. Exercícios de Laboratório
Paulo Sérgio Rodrigues Exercícios de Laboratório Iluminação São Bernardo do Campo, SP Abril de 2010 Iluminação Como é possível observar na Fig. 1, a imagem gerada não possui uma qualidade satisfatória.
Introdução à Programação. Armazenamento de Grande Quantidade de Informação Usando Vetores
Introdução à Programação Armazenamento de Grande Quantidade de Informação Usando Vetores Armazenando Grande Quantidade de Informação Como armazenar tanta informação? Vetores! 2 Tópicos da Aula Hoje, aprenderemos
1. Evolução do OpenGL
Universidade Federal de Santa Maria Departamento de Eletrônica e Computação Prof. Cesar Tadeu Pozzer Disciplina: Computação Gráfica Avançada [email protected] 04/12/2012 OpenGL Shading Language 1. Evolução
8. Síntese de Imagens: Cálculo de Cor
8. Síntese de Imagens: Cálculo de Cor O processo de determinar a aparência (ou seja, a textura e a cor) das superfícies visíveis é chamado de shading. Essa aparência da superfície depende das propriedades
FCG2006 Prova sobre OpenGL e Rastreamento de Raios
FCG2006 Prova sobre OpenGL e Rastreamento de Raios Aluno(a): matrícula: 1. O programa SimpleLight.c mostrado no Quadro 1 produz a janela mostrada na Figura 1. A partir do código, calcule coordenadas na
Computação Gráfica. Iluminação
Computação Gráfica Iluminação António Ramires Fernandes + Luís Paulo Santos - Computação Gráfica 08/09 Iluminação Tópicos: Fundamentos de iluminação Aplicação em OpenGL Modelos de Shading Materiais em
Computação Gráfica. Iluminação
Computação Gráfica Iluminação António nio Ramires Fernandes - Multimédia Iluminação Tópicos: Fundamentos de iluminação Aplicação em OpenGL Modelos de Shading Materiais em OpenGL Iluminação em OpenGL DI-UM
INSTITUTO TECNOLÓGICO
PAC - PROGRAMA DE APRIMORAMENTO DE CONTEÚDOS. ATIVIDADES DE NIVELAMENTO BÁSICO. DISCIPLINAS: MATEMÁTICA & ESTATÍSTICA. PROFº.: PROF. DR. AUSTER RUZANTE 1ª SEMANA DE ATIVIDADES DOS CURSOS DE TECNOLOGIA
Fundamentos de Computação Gráfica. Iluminação
Fundamentos de Computação Gráfica Iluminação Iluminação Tópicos: Fundamentos de iluminação Aplicação em OpenGL Modelos de Shading Materiais em OpenGL Iluminação em OpenGL 2 Iluminação Em CG a iluminação
Sistemas de Apoio à Decisão
Sistemas de Apoio à Decisão Processo de tomada de decisões baseia-se em informação toma em consideração objectivos toma em consideração conhecimento sobre o domínio. Modelar o processo de tomada de decisões
Apontamentos de Computação Gráfica
Apontamentos de Computação Gráfica Capítulo 9 - Iluminação e Texturas em Gráficos 3D Prof. João Beleza Sousa Prof. Arnaldo Abrantes LEIC/DEETC/ISEL Novembro de 2008 Introdução Luzes Modelos de Iluminação
Busca em Memória. Secundária
UNIVERSIDADE ESTADUAL DE MARINGÁ DEPARTAMENTO DE INFORMÁTICA Busca em Memória Secundária e Gomes da Costa [email protected] 1 Busca de um item em uma massa de dados que não cabe na memória principal; Procura-se
Programação Engenharia Informática (11543) 1º ano, 1º semestre Tecnologias e Sistemas de Informação (6619) 1º ano, 1º semestre
Programação Engenharia Informática (11543) 1º ano, 1º semestre Tecnologias e Sistemas de Informação (6619) 1º ano, 1º semestre Cap. 02 Fundamentos de Linguagens Sumário : Linguagem, alfabeto e gramática
INTRODUÇÃO À LINGUAGEM C++
INTRODUÇÃO À LINGUAGEM C++ 1 - VARIÁVEIS Variáveis espaço de memória reservado para armazenar tipos de dados, com um nome para referenciar seu conteúdo. Observações importantes Todas as variáveis devem
MATEMÁTICA GEOMETRIA ANALÍTICA I PROF. Diomedes. E2) Sabendo que a distância entre os pontos A e B é igual a 6, calcule a abscissa m do ponto B.
I- CONCEITOS INICIAIS - Distância entre dois pontos na reta E) Sabendo que a distância entre os pontos A e B é igual a 6, calcule a abscissa m do ponto B. d(a,b) = b a E: Dados os pontos A e B de coordenadas
Universidade de Brasília Instituto de Ciências Exatas Departamento de Ciência da Computação. Shader Não Fotorrealístico para Desenho de Mangás
Universidade de Brasília Instituto de Ciências Exatas Departamento de Ciência da Computação Shader Não Fotorrealístico para Desenho de Mangás Johnny Ahrens Monografia apresentada como requisito parcial
Tipo de Dados em Linguagem C
Tipo de Dados em Linguagem C Principais tipos de dados em C int : tipo de dados inteiros (exemplo: 1, -3, 100, -9, 18, etc.) float : tipo de dados reais (exemplo: 1.33, 3.14, 2.00, -9.0, 1.8, etc.) Ocupa
Equações Diferenciais Ordinárias
Equações Diferenciais Ordinárias Uma equação diferencial é uma equação que relaciona uma ou mais funções (desconhecidas com uma ou mais das suas derivadas. Eemplos: ( t dt ( t, u t d u ( cos( ( t d u +
Computação Gráfica. Modelo de sombreamento Determina como o modelo de iluminação será aplicado e quais seus argumentos
Computação Gráfica Iluminação Prof. Rodrigo Rocha [email protected] Introdução Determinação da cor envolve Além das propriedades da superfícies Cor, textura, material,... Incidência da luz Shading
Programação: Estruturas de seleção
Programação de Computadores I Aula 07 Programação: Estruturas de seleção José Romildo Malaquias Departamento de Computação Universidade Federal de Ouro Preto 2011-1 1/53 Valores booleanos Os valores booleanos
Truques e Dicas. = 7 30 Para multiplicar fracções basta multiplicar os numeradores e os denominadores: 2 30 = 12 5
Truques e Dicas O que se segue serve para esclarecer alguma questão que possa surgir ao resolver um exercício de matemática. Espero que lhe seja útil! Cap. I Fracções. Soma e Produto de Fracções Para somar
Modelos de Iluminação Métodos de surface-rendering. Beatriz Sousa Santos, J. Madeira
Modelos de Iluminação Métodos de surface-rendering Beatriz Sousa Santos, J. Madeira 1 As imagens realistas obtêm-se : usando projecções perspectivas da cena aplicando efeitos de iluminação naturais às
14.1 Vetor - Problemas
Problema 14: Um método de Criptografia consiste em substituir as letras de uma mensagem através do emparelhamento de alfabetos tal como dado abaixo. Construir um programa que codifica mensagens usando
Computação Gráfica - 13
Universidade Federal do Vale do São Francisco Curso de Engenharia da Computação Computação Gráfica - 13 Prof. Jorge Cavalcanti [email protected] www.univasf.edu.br/~jorge.cavalcanti www.twitter.com/jorgecav
Computação Gráfica. GLSL - Introdução e Programação da Aplicação OpenGL
Computação Gráfica GLSL - Introdução e Programação da Aplicação OpenGL António nio Ramires Fernandes - Multimédia Evolução do Hardware Gráfico PCs Controladores VGA (Video Graphics Array) Introduzido em
Instituto Superior Técnico Departamento de Matemática Última actualização: 11/Dez/2003 ÁLGEBRA LINEAR A
Instituto Superior Técnico Departamento de Matemática Secção de Álgebra e Análise Última actualização: 11/Dez/2003 ÁLGEBRA LINEAR A FICHA 8 APLICAÇÕES E COMPLEMENTOS Sistemas Dinâmicos Discretos (1) (Problema
Computação Gráfica. Renderização em Tempo Real. Erivaldo Xavier de Lima Filho [email protected]
Computação Gráfica Renderização em Tempo Real Erivaldo Xavier de Lima Filho [email protected] Computação Gráfica É a síntese de imagens por computador Consiste de vários passos: o Modelagem o Renderização
Programação por Objectos. Java
Programação por Objectos Java Parte 3: Métodos LEEC@IST Java 1/45 Métodos (1) Sintaxe Qualif Tipo Ident ( [ TipoP IdentP [, TipoP IdentP]* ] ) { [ Variável_local Instrução ]* Qualif: qualificador (visibilidade,
Iluminação (lighting) e Sombreamento (shading)
Iluminação (lighting) e Sombreamento (shading) Cap 16: Foley Cap 5: OpenGL Aula 11: Notas do Dave Revisão Coordenadas padrão Ponto Coordenadas da janela Matriz Modelview Transformação p/ Viewport Coordenadas
Notas sobre a Fórmula de Taylor e o estudo de extremos
Notas sobre a Fórmula de Taylor e o estudo de etremos O Teorema de Taylor estabelece que sob certas condições) uma função pode ser aproimada na proimidade de algum ponto dado) por um polinómio, de modo
1. Fazer um programa em C que pergunta um valor em metros e imprime o correspondente em decímetros, centímetros e milímetros.
Lista de exercícios: Grupo I - programa seqüênciais simples 1. Fazer um programa em C que pergunta um valor em metros e imprime o correspondente em decímetros, centímetros e milímetros. 2. Fazer um programa
9 Comandos condicionais
9 Comandos condicionais Um comando condicional é uma instrução empregada quando se deseja criar um desvio, isto é, a opção de executar-se ou não um determinado trecho de código, segundo uma condição. Em
7. Estrutura de Decisão
7. Estrutura de Decisão Neste tipo de estrutura o fluxo de instruções a ser seguido é escolhido em função do resultado da avaliação de uma ou mais condições. Uma condição é uma expressão lógica. A classificação
CG 2013/2014 Primeiro Teste LEIC Alameda/Taguspark
Computação Gráfica Licenciatura em Engenharia Informática e de Computadores Alameda / Taguspark Primeiro Teste 6 de Outubro de 013 O teste tem a duração de 1h00, tolerância incluída. Responda às questões
Problema. Conversão Matricial. Octantes do Sistema de Coordenadas Euclidiano. Sistema de Coordenadas do Dispositivo. Maria Cristina F.
Problema Conversão Matricial Maria Cristina F. de Oliveira Traçar primitivas geométricas (segmentos de reta, polígonos, circunferências, elipses, curvas,...) no dispositivo matricial rastering = conversão
Estrutura Condicional em Java
Estrutura Condicional em Java Linguagem de Programação 1 O Java contém três tipos de instruções de seleção. A instrução if realiza uma ação se uma condição for verdadeira ou pula a ação se a condição for
Algoritmos e Programação
Universidade Federal do Vale do São Francisco Curso de Engenharia da Produção / Elétrica Algoritmos e Programação Parte 05 Prof. Jorge Cavalcanti [email protected] www.univasf.edu.br/~jorge.cavalcanti
Exercícios de Revisão Java Básico
Exercícios de Revisão Java Básico (i) Programação básica (estruturada) 1) Faça um programa para calcular o valor das seguintes expressões: S 1 = 1 1 3 2 5 3 7 99... 4 50 S 2 = 21 50 22 49 23 48...250 1
Classificação da imagem (ou reconhecimento de padrões): objectivos Métodos de reconhecimento de padrões
Classificação de imagens Autor: Gil Gonçalves Disciplinas: Detecção Remota/Detecção Remota Aplicada Cursos: MEG/MTIG Ano Lectivo: 11/12 Sumário Classificação da imagem (ou reconhecimento de padrões): objectivos
Preenchimento de Áreas e de Polígonos. Antonio L. Bajuelos Departamento de Matemática Universidade de Aveiro
Preenchimento de Áreas e de Polígonos (Filled-Area Primitives) Antonio L. Bajuelos Departamento de Matemática Universidade de Aveiro Preenchimento de áreas é o processo de coloração do interior de uma
Projeções e Visualização
Computação Gráfica 5385: Licenciatura em Engenharia Informática Cap. 4 Projeções e Visualização Projeções e Visualização Sumário Pipeline de Visualização em OpenGL x y z w vértice original MODELVIEW matrix
Luiz Gonzaga da Silveira Jr
Luiz Gonzaga da Silveira Jr O p e n G L evolução recente Luiz Gonzaga da Silveira Jr OpenGL 4.x: D3D a guerra não acabou OpenGL 4.2 - novas funcionalidades: Contadores atômicos para shaders Tesselação
Linguagens de Programação
Linguagens de Programação Prof. Miguel Elias Mitre Campista http://www.gta.ufrj.br/~miguel Parte IV Introdução à Programação em C++ (Continuação) Relembrando da Última Aula... Funções Classes de armazenamento
Programação. MEAer. Bertinho Andrade da Costa. Instituto Superior Técnico. Introdução ao Pré-Processador. 2011/2012 1º Semestre
Programação MEAer Bertinho Andrade da Costa 2011/2012 1º Semestre Instituto Superior Técnico Introdução ao Pré-Processador Programação 2011/2012 DEEC-IST Introdução ao Pré-Processador 1 Sumário Introdução
Exercícios 1. Determinar x de modo que a matriz
setor 08 080509 080509-SP Aula 35 MATRIZ INVERSA Uma matriz quadrada A de ordem n diz-se invertível, ou não singular, se, e somente se, existir uma matriz que indicamos por A, tal que: A A = A A = I n
Técnicas de Computação Paralela Capítulo III Design de Algoritmos Paralelos
Técnicas de Computação Paralela Capítulo III Design de Algoritmos Paralelos José Rogado [email protected] Universidade Lusófona Mestrado Eng.ª Informática e Sistemas de Informação 2013/14 Resumo
Cálculo em Computadores - 2007 - trajectórias 1. Trajectórias Planas. 1 Trajectórias. 4.3 exercícios... 6. 4 Coordenadas polares 5
Cálculo em Computadores - 2007 - trajectórias Trajectórias Planas Índice Trajectórias. exercícios............................................... 2 2 Velocidade, pontos regulares e singulares 2 2. exercícios...............................................
Estrutura de Dados Básica
Estrutura de Dados Básica Professor: Osvaldo Kotaro Takai. Aula 4: Tipos de Dados O objetivo desta aula é apresentar os tipos de dados manipulados pela linguagem C, tais como vetores e matrizes, bem como
Universidade da Beira Interior Cursos: Matemática /Informática e Ensino da Informática
Folha 1-1 Introdução à Linguagem de Programação JAVA 1 Usando o editor do ambiente de desenvolvimento JBUILDER pretende-se construir e executar o programa abaixo. class Primeiro { public static void main(string[]
Cálculo Numérico Faculdade de Engenharia, Arquiteturas e Urbanismo FEAU
Cálculo Numérico Faculdade de Engenharia, Arquiteturas e Urbanismo FEAU Prof. Dr. Sergio Pilling (IPD/ Física e Astronomia) III Resolução de sistemas lineares por métodos numéricos. Objetivos: Veremos
Operações com números racionais decimais
Divisão 1º: Divisão exata Operações com números racionais decimais Considere a seguinte divisão: 1,4 : 0,05 Transformando em frações decimais, temos: Método prático 1º) Igualamos o números de casas decimais,
Desmistificando Shaders em XNA 4.0
Desmistificando Shaders em XNA 4.0 Bruno Duarte Correa Thiago Dias Pastor Department of Computer and Digital Systems Engineering, Escola Politécnica da Universidade de São Paulo, Brazil 1 Introdução 3.2
4. Tangentes e normais; orientabilidade
4. TANGENTES E NORMAIS; ORIENTABILIDADE 91 4. Tangentes e normais; orientabilidade Uma maneira natural de estudar uma superfície S consiste em considerar curvas γ cujas imagens estão contidas em S. Se
Linguagem de Programação JAVA. Técnico em Informática Professora Michelle Nery
Linguagem de Programação JAVA Técnico em Informática Professora Michelle Nery Agenda Regras paravariáveis Identificadores Válidos Convenção de Nomenclatura Palavras-chaves em Java Tipos de Variáveis em
Coordenadas Polares Mauri C. Nascimento Dep. De Matemática FC Unesp/Bauru
Coordenadas Polares Mauri C. Nascimento Dep. De Matemática FC Unesp/Bauru Dado um ponto P do plano, utilizando coordenadas cartesianas (retangulares), descrevemos sua localização no plano escrevendo P
Linguagem C Tipos de Dados. void; escalares; sizeof Vectores; strings em C Estruturas Introdução ao pré-processador
Linguagem C Tipos de Dados void; escalares; sizeof Vectores; strings em C Estruturas Introdução ao pré-processador Funções void void pode ser usado em lugar de um tipo, para indicar a ausência de valor
E/S CPU. Memória (Instruções e dados) 2 PARADIGMA IMPERATIVO. Instruções e dados. Resultados das operações. Unidade lógica e aritmética
2 PARADIGMA IMPERATIVO 2.1 CONCEITO As linguagens que pertencem ao paradigma imperativo tomam por base a perspectiva da máquina. Ou seja, no modo como o computador executa programas em linguagem de máquina.
Introdução ao MATLAB
Introdução ao MATLAB O MATLAB é um programa cálculo numérico que pode ser usado interactivamente. A sua estrutura de dados fundamental é a matriz, que pode ter elementos reais ou complexos. Embora na sua
Conversão de Tipos e Arrays
Conversão de Tipos e Arrays Universidade Católica de Pernambuco Ciência da Computação Prof. Márcio Bueno [email protected] Fonte: Material da Profª Karina Oliveira Conversão de Tipos Permite converter
Nestas condições, determine a) as coordenadas dos vértices B, C, D, E e F e a área do hexágono ABCDEF. b) o valor do cosseno do ângulo AÔB.
MATEMÁTICA 0 A figura representa, em um sistema ortogonal de coordenadas, duas retas, r e s, simétricas em relação ao eixo Oy, uma circunferência com centro na origem do sistema, e os pontos A = (1, ),
Capítulo 8. Introdução UML
Capítulo 8. Introdução UML 1/42 Índice Indice 8.1 - Introdução UML 8.2 - Modelação estrutural 8.2.1 - Representação de classes e objectos 8.2.2 - Relações entre objectos 8.2-3 - Relações de associação
Potenciação no Conjunto dos Números Inteiros - Z
Rua Oto de Alencar nº 5-9, Maracanã/RJ - tel. 04-98/4-98 Potenciação no Conjunto dos Números Inteiros - Z Podemos epressar o produto de quatro fatores iguais a.... por meio de uma potência de base e epoente
ESTUDO GRÁFICO DOS MOVIMENTOS. Gráfico posição x tempo (x x t)
ESTUDO GRÁFICO DOS MOVIMENTOS No estudo do movimento é bastante útil o emprego de gráficos. A descrição de um movimento a partir da utilização dos gráficos (posição x tempo; velocidade x tempo e aceleração
Bruno Pereira Evangelista. www.brunoevangelista.com
Bruno Pereira Evangelista www.brunoevangelista.com 2 Introdução Shaders Pipeline de Renderização Evolução dos Shaders Como Programar Shaders Programando Shaders com XNA Ferramentas Conclusões 3 Durante
Evocar os conceitos do MRUV (movimento retilíneo uniformemente variado), do MRU (movimento retilíneo uniforme) e a decomposição de forças.
14 Curso Básico de Mecânica dos Fluidos Objetivos da segunda aula da unidade 1: Evocar os conceitos do MRUV (movimento retilíneo uniformemente variado), do MRU (movimento retilíneo uniforme) e a decomposição
5 - Vetores e Matrizes Linguagem C CAPÍTULO 5 VETORES E MATRIZES
CAPÍTULO 5 5 VETORES E MATRIZES 5.1 Vetores Um vetor armazena uma determinada quantidade de dados de mesmo tipo. Vamos supor o problema de encontrar a média de idade de 4 pessoas. O programa poderia ser:
Linguagem C Funções definidas pelo usuário. Lógica de Programação
Linguagem C Funções definidas pelo usuário Lógica de Programação Caro(a) aluno(a), Trabalharemos agora com as funções criadas por vocês na Linguagem C. Bom trabalho!!! Funções C permite que o programador
MA.01. 4. Sejam a e b esses números naturais: (a + b) 3 (a 3 + b 3 ) = a 3 + 3a 2 b + 3ab 2 + b 3 a 3 b 3 = = 3a 2 b + 3ab 2 = 3ab (a + b)
Reformulação Pré-Vestibular matemática Cad. 1 Mega OP 1 OP MA.01 1.. 3. 4. Sejam a e b esses números naturais: (a + b) 3 (a 3 + b 3 ) a 3 + 3a b + 3ab + b 3 a 3 b 3 3a b + 3ab 3ab (a + b) Reformulação
Universidade Federal de Rondônia Técnicas de Desenvolvimento de Programas Lista 4
Universidade Federal de Rondônia Técnicas de Desenvolvimento de Programas Lista 4 WHILE 1. Faça um comando while equivalente ao descrito abaixo (que realize o mesmo tipo de procedimento e obtenha o mesmo
Introdução ao OpenGL 2.1 e GLSL 1.2
Introdução ao OpenGL 2.1 e GLSL 1.2 Felipe Bessa Coelho Universidade de São Paulo 25 de Setembro de 2012 Felipe Bessa Coelho (USP) OpenGL+GLSL 2012 1 / 49 Sumário 1 Objetivos 2 Transformações geométricas
Q1 Q2 Q3 Nota. Departamento de Informática - PUC-Rio INF 1005 Programação I P2 20/10/2010. Aluno: Exemplo (apenas um exemplo!):
Matrícula: Departamento de Informática - PUC-Rio Turma: Q1 Q2 Q3 Questão 1) (3.0 pontos) Uma empresa permite que seus funcionários façam chamadas internacionais a partir de seus ramais, mas mantém um registro
Prof. Rossini Bezerra Faculdade Boa Viagem
Sistemas de Coordenadas Polares Prof. Rossini Bezerra Faculdade Boa Viagem Coordenadas Polares Dado um ponto P do plano, utilizando coordenadas cartesianas (retangulares), descrevemos sua localização no
UFPB PRG X ENCONTRO DE INICIAÇÃO À DOCÊNCIA
4CCENDMMT03 ABELHA: GEOMETRIA DOS ALVÉOLOS Thiago Pereira Rique (1), Jorge Costa Duarte Filho (3) Centro de Ciências Exatas e da Natureza/Departamento de Matemática/Monitoria Resumo Este trabalho tem por
Utilização. de Shaders de efeitos realistas para jogos. Bruno Pereira Evangelista. Pontifícia Universidade Católica de Minas Gerais
Utilização de Shaders para criação de efeitos realistas para jogos Bruno Pereira Evangelista Pontifícia Universidade Católica de Minas Gerais Sumário 2/48 Apresentação pessoal Introdução Pipeline de renderização
Recursividade. Aula 9
Recursividade Aula 9 Em matemática vários objetos são definidos apresentando-se um processo que os produz. Ex PI (circunferência/diâmetro) Outra definição de um objeto por um processo é o fatorial de um
Gráficos de funções em calculadoras e com lápis e papel (*)
Rafael Domingos G Luís Universidade da Madeira/Escola Básica /3 São Roque Departamento de Matemática Gráficos de funções em calculadoras e com lápis e papel (*) A difusão de calculadoras gráficas tem levado
UNESP DESENHO TÉCNICO: Fundamentos Teóricos e Introdução ao CAD. Parte 3/5: Prof. Víctor O. Gamarra Rosado
UNESP UNIVERSIDADE ESTADUAL PAULISTA FACULDADE DE ENGENHARIA CAMPUS DE GUARATINGUETÁ DESENHO TÉCNICO: Fundamentos Teóricos e Introdução ao CAD Parte 3/5: 8. Projeções ortogonais 9. Terceira Vista 10. Tipos
Programação Orientada a Objetos C++
Programação Orientada a Objetos em C++ Sumário Histórico Comparação com Java Encapsulamento Tratamento de classes e objetos Herança Polimorfismo Histórico Desenvolvido por Bjarne Stroustrup dos Bell Labs
