首页
网站开发
桌面应用
管理软件
微信开发
App开发
嵌入式软件
工具软件
数据采集与分析
其他
首页
>
> 详细
代写data编程、代做C/C++, Python,Java编程
项目预算:
开发周期:
发布时间:
要求地区:
For this assignment, you will be building a Ray Tracer using C/C++, Python, or Java. The choice of which of these languages is up to you, but keep in mind that language-specific support is not provided (you should use the language you can locally support and are comfortable coding in). The system only needs to handle the rendering of ellipsoids (transformed spheres), with a fixed camera situated at the origin in a right-handed coordinate system, looking down the negative z-axis. Local illumination, reflections, and shadows will also need to be implemented.
The program should take a single argument, which is the name of the file to be parsed. Make sure your executable has the name “RayTracer.exe” (or equivalent for the language you choose) and that we can run it as in the following examples:
> RayTracer.exe testCase1.txt
or
> java RayTracer testCase1.txt
or
> python RayTracer.py testCase1.txt
We will use a script to generate the outputs for the set of posted test cases. You will get zero marks if we cannot compile your program and if we cannot run this script because your project does not implement the required specifications above.
Make sure you carefully read the Instructions and Clarifications below as they contain important information on the lighting, scene setup, tracing depth etc.
Input File Format
The content and syntax of the file is as follows:
File Content
* integer ** float(s) *** float(s) between 0 and 1
1.The near plane**, left**, right**, top**, and bottom**
2.The resolution of the image nColumns* X nRows*
3.The position** and scaling** (non-uniform), color***, Ka***, Kd***, Ks***, Kr*** and the specular exponent n* of a sphere
4.The position** and intensity*** of a point light source
5.The background colour***
6.The scene’s ambient intensity***
7.The output file name (you should limit this to 20 characters with no spaces)
File Syntax
Do not write the angle brackets, these are to show you where to insert values. See the testcase files!
NEAR
LEFT
RIGHT
BOTTOM
TOP
RES
SPHERE
… // up to 14 additional sphere specifications
LIGHT
… // up to 9 additional light specifications
BACK
AMBIENT
OUTPUT
All names should be limited to 20 characters, with no spaces. All fields are separated by spaces. There will be no angle brackets in the input file. The ones above are used to indicate the fields.
Output File Format
You should output your images in PPM format. You can choose binary (P6) or text-based ppm (P3). The text-based format is very simple, but it is important to understand the assumptions about which pixel is where (where (0,0) is for example). Example code for these has been provided in C++ attached to the assignment. We must be able to open your output files in a viewer that is freely available see clarifications below.
https://netpbm.sourceforge.net/doc/ppm.html
Marking Scheme
Total Marks: 26
1.[2] Coding Style (i.e. well designed, clean, & commented code)
2.[2] x 12 For each of the given test cases.
3.[-4 Marks if not] Provide a readme.txt that describes what you have done, what you have omitted, and any other information that will help the grader evaluate your work, including what is stated below.
There will be no partial marks given if your program fails to parse an input file or if it does not produce the correct output.
Make sure you submit all the required files so we can compile and build your program. If there are missing libraries, you will get zero marks.
We will use a script to generate the outputs for a set of test cases. You will get zero marks if we cannot run this script because your program does not adhere to the given requirements. (Repeated for emphasis)
Requirements/Policies
Collaboration
None. If you discuss this assignment with others, you should submit their names along with the assignment material.
Original Work
The assignment must be done from scratch. Apart from the code provided, you should not use code from any other source, including the previous offering of the class. (see clarifications below)
Zero Mark
If the code does not run, no objects appear in the window, or only any template/given code is running properly, no partial marks will be given.
INSTRUCTIONS AND CLARIFICATIONS
●Start working on A3 early. You will not have time to do it at the last minute.
●Your submission should include ALL of the code necessary to compile and run the program, and should not contain any additional functionality besides what is described here. It should not contain any OpenGL API calls. You may use OpenGL to display the results during your debugging.
●You may use vector and matrix libraries, i.e. any vector matrix libraries for C/C++ (e.g. GLM), Java (JAMA, EJML), or Python (NumPy). You cannot use library code that solves any part of the raytracing problem on its own, you must write this code yourself. It must be clear how to set up your code, and, if possible, all libraries *must* be included. If we cannot set up your code we cannot mark it.
●In the assignment attachments, you will find two pieces of example C++ code. One inverts a 4x4 matrix, and the other writes a char buffer to a ppm image, which is the expected output of this program.
●The code that inverts a 4x4 matrix expects two 4x4 matrices to be passed in as arguments. The first matrix will be inverted and the result will be stored in the second matrix. Both matrices are row order storage, so you have M[row][column].
●You may use the STL string and vector classes.
●The assignment must be done from scratch.
●Make sure that your parse routine does not crash based on where the EOF character is.
●Given a reasonable resolution (400x400) on a modern machine, your program should generally take no more than five to twenty seconds (probably less than that) to run when compiled in “release” mode. Interpreted languages may take longer, but if the files do not return within a reasonable time the case will fail. For interpreted languages, reasonable may be upwards of a minute.
●A sphere at position (0,0,0), with scaling parameters (1,1,1) should be centred at (0,0,0) with a radius of 1.
●If the eye ray is constructed using the convention described in class, then when intersecting it with an object, the closest object is the one with a minimum hit time greater than 1. A hit time between 0 and 1 falls between the eye and the near plane, and hence is not a part of the view volume.
●When creating rays from the closest hit point on an object, you need to start them at t = 0.000001, (try a larger number like t = 0.0001 if this does not work), to avoid false intersections due to numerical errors. In other words, you may not want to consider intersections at t=0.
●For the keys and results, we use the following convention: Rays from the eye that hit nothing return the colour of the background, while reflected rays that hit nothing return black (i.e. nothing).
●The template code for saving your image to disk uses the ppm image format. If you do not already have a program that can read images of this type, you can download, GIMP (recommended!), IfranView (www.irfanview.com), or Xnviewgb. These are excellent and free programs for viewing images, and can, amongst others, read ppm files.
●The “NEAR” value is an absolute value and represents the distance along the negative z-axis.
●Your code may need to handle hollow spheres, which are “cut” open by the near plane.
●Your code may need to be able to handle lights inside spheres.
●You will be using the following local illumination model (what we learned in class, apply the ADS lighting to a point assuming reflected rays contribute):
○PIXEL_COLOR[c] = Ka*Ia[c]*O[c] +
for each point light (p) { Kd*Ip[c]*(N dot L)*O[c]+Ks*Ip[c]*(R dot V)n } +
Kr*(Color returned from reflection ray)
○O is the object color (
)
○[c] means that the variable has three different colour components, so the value may vary depending on whether the red, green, or blue colour channel is being calculated
○The other components of this equation are explained in the lecture notes.
●You should not spawn more than three reflection rays for each pixel, i.e. stop the recursion after 3 bounces.
●When summing over all lights, it is possible for the PIXEL_COLOR value to go above 1. In this case, the simplest solution is to clamp the value to 1.
●Do not forget to scale by 255 before creating the ppm image
○(C/C++) using the given “save_imageP6()” function in ppm.cpp. “save_imageP3()” is provided for debugging reasons because it produces a human-readable text file. The P6 version produces a binary file. You are welcome to produce the human-readable format for any of the available languages, as long as it can be opened by an image reader listed above.
●Make sure you submit all the required files so we can compile and build your program. If there are missing libraries, you will get zero marks. (C/C++) On Linux, we should be able to compile by just typing make “make”, and, on Windows, with MS VS -> Build. Make it clear in your readme how your code is compiled.
●(C/C++) Make sure that your Visual Studio project is designed to create a “Console Application” or “Command Line Tool”.
●Make sure that everything works on a standard Windows machine as this is what the lab and TAs support. (However, you should avoid using platform-dependent code, like the Windows API. You do not need it here.)
●(C/C++) Make sure you “clean” your project before zipping it and submitting it, to remove all the large auxiliary files that VS creates.
●Make sure you check regularly the forum and the announcements in case the grading or submission instructions change.
软件开发、广告设计客服
QQ:99515681
邮箱:99515681@qq.com
工作时间:8:00-23:00
微信:codinghelp
热点项目
更多
代写dts207tc、sql编程语言代做
2024-12-25
cs209a代做、java程序设计代写
2024-12-25
cs305程序代做、代写python程序...
2024-12-25
代写csc1001、代做python设计程...
2024-12-24
代写practice test preparatio...
2024-12-24
代写bre2031 – environmental...
2024-12-24
代写ece5550: applied kalman ...
2024-12-24
代做conmgnt 7049 – measurem...
2024-12-24
代写ece3700j introduction to...
2024-12-24
代做adad9311 designing the e...
2024-12-24
代做comp5618 - applied cyber...
2024-12-24
代做ece5550: applied kalman ...
2024-12-24
代做cp1402 assignment - netw...
2024-12-24
热点标签
mktg2509
csci 2600
38170
lng302
csse3010
phas3226
77938
arch1162
engn4536/engn6536
acx5903
comp151101
phl245
cse12
comp9312
stat3016/6016
phas0038
comp2140
6qqmb312
xjco3011
rest0005
ematm0051
5qqmn219
lubs5062m
eee8155
cege0100
eap033
artd1109
mat246
etc3430
ecmm462
mis102
inft6800
ddes9903
comp6521
comp9517
comp3331/9331
comp4337
comp6008
comp9414
bu.231.790.81
man00150m
csb352h
math1041
eengm4100
isys1002
08
6057cem
mktg3504
mthm036
mtrx1701
mth3241
eeee3086
cmp-7038b
cmp-7000a
ints4010
econ2151
infs5710
fins5516
fin3309
fins5510
gsoe9340
math2007
math2036
soee5010
mark3088
infs3605
elec9714
comp2271
ma214
comp2211
infs3604
600426
sit254
acct3091
bbt405
msin0116
com107/com113
mark5826
sit120
comp9021
eco2101
eeen40700
cs253
ece3114
ecmm447
chns3000
math377
itd102
comp9444
comp(2041|9044)
econ0060
econ7230
mgt001371
ecs-323
cs6250
mgdi60012
mdia2012
comm221001
comm5000
ma1008
engl642
econ241
com333
math367
mis201
nbs-7041x
meek16104
econ2003
comm1190
mbas902
comp-1027
dpst1091
comp7315
eppd1033
m06
ee3025
msci231
bb113/bbs1063
fc709
comp3425
comp9417
econ42915
cb9101
math1102e
chme0017
fc307
mkt60104
5522usst
litr1-uc6201.200
ee1102
cosc2803
math39512
omp9727
int2067/int5051
bsb151
mgt253
fc021
babs2202
mis2002s
phya21
18-213
cege0012
mdia1002
math38032
mech5125
07
cisc102
mgx3110
cs240
11175
fin3020s
eco3420
ictten622
comp9727
cpt111
de114102d
mgm320h5s
bafi1019
math21112
efim20036
mn-3503
fins5568
110.807
bcpm000028
info6030
bma0092
bcpm0054
math20212
ce335
cs365
cenv6141
ftec5580
math2010
ec3450
comm1170
ecmt1010
csci-ua.0480-003
econ12-200
ib3960
ectb60h3f
cs247—assignment
tk3163
ics3u
ib3j80
comp20008
comp9334
eppd1063
acct2343
cct109
isys1055/3412
math350-real
math2014
eec180
stat141b
econ2101
msinm014/msing014/msing014b
fit2004
comp643
bu1002
cm2030
联系我们
- QQ: 9951568
© 2021
www.rj363.com
软件定制开发网!