aboutsummaryrefslogtreecommitdiff
path: root/advtrains_train_track/textures/advtrains_dtrack_bumper_placer.png
blob: 27191fe40d8e39b1a02e52729c41039f34b4a68b (plain)
ofshex dumpascii
0000 89 50 4e 47 0d 0a 1a 0a 00 00 00 0d 49 48 44 52 00 00 00 38 00 00 00 38 08 06 00 00 00 a8 86 3b .PNG........IHDR...8...8.......;
0020 1e 00 00 00 06 62 4b 47 44 00 ff 00 ff 00 ff a0 bd a7 93 00 00 00 09 70 48 59 73 00 00 0b 13 00 .....bKGD..............pHYs.....
0040 00 0b 13 01 00 9a 9c 18 00 00 00 07 74 49 4d 45 07 e0 0b 0a 14 06 3b 3e 83 25 59 00 00 00 19 74 ............tIME......;>.%Y....t
0060 45 58 74 43 6f 6d 6d 65 6e 74 00 43 72 65 61 74 65 64 20 77 69 74 68 20 47 49 4d 50 57 81 0e 17 EXtComment.Created.with.GIMPW...
0080 00 00 08 0d 49 44 41 54 68 de dd 9a 6d 4c 5b e7 15 c7 ff 8f 31 2f b1 71 1a 63 42 80 a5 7e 49 91 ....IDATh...mL[.....1/.q.cB..~I.
00a0 89 d3 1a 8c 0d 68 4d 80 b0 4d 59 9a 97 26 6a 9b 32 29 cd 96 49 d9 d2 84 36 1d d5 16 5a 1a 69 ab .....hM..MY..&j.2)..I...6...Z.i.
00c0 16 29 89 9a 49 6b d4 aa d5 9a a1 56 6a fb 85 6e 69 36 69 c9 3a 28 33 0b 4e 60 29 10 25 69 a0 90 .)..Ik.....Vj..ni6i.:(3.N`).%i..
00e0 05 70 57 53 1b 6a 13 de 62 5c ec 67 1f bc 7b b9 b6 ef b5 8d 73 53 70 8f e4 0f dc 7b 78 ae 7f 3a .pWS.j..b\.g..{.....sSp....{x..:
0100 ff f3 7f ce 73 65 72 74 9f 9e 82 13 1b 4d 59 e8 77 cc 01 00 32 d2 52 d8 eb 87 df b2 13 24 61 90 ....sert.....MY.w...2.R......$a.
0120 bd 5b d4 14 00 0a f2 33 f0 6d 04 95 e4 aa 96 01 00 6e 3a bc 58 db d8 cf de 68 bb e2 c6 88 6b 02 .[.....3.m.......n:.X....h....k.
0140 fa 7c 29 bc 3e 3f bc 3e 3f 00 e0 e4 7e 35 3d b9 5f 4d 93 a6 82 2f ec 29 a4 00 50 fa de 67 21 37 .|).>?.>?...~5=._M.../.)..P..g!7
0160 fa f6 e9 bf 15 15 95 48 53 00 69 4a e4 8d b5 8d fd b8 e9 f0 26 7d 45 25 b1 12 6e 3a bc 49 0d 4a .......HS.iJ........&}E%..n:.I.J
0180 76 6f 5a 4d 01 e0 b1 e6 ff f2 26 7c b2 a7 10 5f 7e 75 87 fd 3b d9 cc 48 b2 52 29 8b 99 94 ab 5a voZM......&|..._~u..;..H.R)....Z
01a0 06 ae 19 25 53 45 c9 2f 6a e6 f7 c1 8a a6 fe 88 84 2b 7b 0b 01 00 73 fe f9 6b c9 54 51 49 b6 02 ...%SE./j........+{...s..k.TQI..
01c0 c8 56 c4 4e e4 9a 51 32 55 94 1c fd 59 21 05 a5 21 ee c9 8d 0f 37 ad 06 00 e8 f2 e5 21 d7 93 a5 .V.N..Q2U...Y!..!....7......!...
01e0 a2 24 2f 2f 0f 00 50 bb 6d 79 04 28 b3 17 f6 da 67 d8 eb c9 06 ca 02 32 11 0e ca 8d 64 04 8d 00 .$//..P.my.(....g......2....d...
0200 5c 4c 50 ea 9f 45 7d a3 53 54 50 c1 8d fe 8d bf 4d 10 68 9f 02 48 e4 f3 0c 6a 19 0c ea e0 f6 32 \LP..E}.STP.....M.h..H...j.....2
0220 e8 98 c6 a0 63 3a 2e 33 12 9a 75 a9 7f 16 d4 3f 7b 4f 24 2a 8d 99 a1 d9 0d 9d 56 83 c1 b6 e3 08 ....c:.3..u....?{O$*......V.....
0240 af 28 03 d9 6b 9f 61 21 99 8a 32 90 73 7e 60 fb 79 7b 84 89 31 fd dd 76 c5 0d 6d 9e ec 9e f5 a0 .(..k.a!..2.s~`.y{..1..v..m.....
0260 24 de 44 dd c6 06 b8 64 3f 4c a8 a2 7c 11 3e eb 8e 78 82 9f 45 03 e4 4a f7 da 44 d1 82 41 a3 cd $.D....d?L..|.>..x..E..J..D..A..
0280 ba 4c 38 46 27 17 1f 10 00 2e b4 db c8 df 7b 55 f0 ae 7a 22 2e 50 a1 d8 7e de 8e 5c d5 32 b4 74 .L8F'.........{U..z".P..~..\.2.t
02a0 4f c2 31 3a 09 83 56 b1 08 3d 28 10 b7 6e 0d 12 00 b4 7a e3 e3 d0 6a d4 f8 f2 f2 ab 82 3d 1a 2b O.1:..V..=(..n....z...j......=.+
02c0 d6 3f a4 58 fc 1e e4 8b 40 20 00 6b 5b 1b 86 86 ed c8 2d ab 43 6e f9 f3 bc 15 ed db a7 8f 38 40 .?.X....@..k[.....-.Cn........8@
02e0 87 f7 e8 dc 5c f0 b3 a4 00 87 86 86 c9 77 f2 f3 31 30 30 80 a1 e1 a0 53 e6 96 d5 c1 ad 78 84 17 ....\........w..100....S.....x..
0300 54 28 18 b0 61 e7 0c 4e be 72 9c 2e 19 40 a6 1f 59 e0 e1 f9 ed c0 9d b9 19 ba ea 97 42 40 f9 aa T(..a..N.r...@..Y...........B@..
0320 38 e8 98 c6 b0 73 06 c3 ce f9 e1 41 4c 48 89 18 8b 5c 68 b7 11 6b 5b 1b 0b b9 ce 60 00 00 74 75 8....s.....ALH...\h..k[....`..tu
0340 75 43 b7 b1 21 04 94 2b d7 f6 1a 3d 98 f3 a8 51 27 83 51 27 e3 40 9e a0 4b 06 90 31 1d 06 12 40 uC..!..+...=...Q'.Q'.@..K..1...@
0360 08 24 b3 8f be 71 6e 92 70 41 99 63 1a 17 6c 3e a8 28 90 12 31 f5 ce 35 1d 2e 64 b4 11 30 fa 59 .$...qn.pA.c..l>.(..1..5..d..0.Y
0380 94 62 49 01 f2 99 ce 3a 83 01 5d 5d dd 08 04 28 76 ed 7a 82 72 47 40 2e 28 29 ac 43 f7 54 55 c4 .bI....:..]]...(v.z.rG@.().C.TU.
03a0 9a 77 db 8f a2 02 0a 99 8e 44 92 82 77 df 7d 1f 25 a6 62 1c 7a f6 19 1a 3e 02 92 c2 3a 00 80 dd .w.......D..w.}.%.b.z...>...:...
03c0 fe 39 2b 69 b1 20 45 05 6c 3a a2 a5 4d 47 b4 d4 94 75 03 03 03 03 2c e4 d4 d4 14 d6 ad 33 e0 fa .9+i..E.l:..MG...u....,......3..
03e0 f5 eb b0 db ed 82 ff ef f1 8c 47 81 4c ac 1f 45 03 7c ec 61 39 1d 1e 0d 00 84 80 68 76 e3 b9 e7 ..........G.L..E.|.a9......hv...
0400 9e c5 96 2d 9b 01 00 72 b9 0c 65 65 16 58 cc 66 4c 4e 4e 08 ae d1 db d7 47 3c 9e 71 5c fe a4 4b ...-...r..ee.X.fLNN.....G<.q\..K
0420 34 d3 11 0d 30 57 29 c1 e7 e9 8f 82 14 1d 43 65 65 05 a6 26 a7 70 e6 cc 87 30 18 0a 61 31 9b e1 4...0W).......Cee..&.p...0..a1..
0440 72 8d 42 b1 7c 39 0e 1e 3c 10 75 9d de be 3e 92 96 9a c6 5b c5 44 20 a5 89 4a 91 ed b9 6b b7 41 r.B.|9..<.u...>....[.D...J...k.A
0460 34 bb 51 59 59 01 00 98 9a 9c c2 3f 9a 9b 61 36 97 c0 62 36 c3 e9 72 a1 a0 a0 00 1a ad 06 b3 b3 4.QYY......?..a6..b6..r.........
0480 3e fc eb bd 5a 60 f5 8f 62 42 2a 95 2b 28 00 58 2c 66 5e c8 c3 f5 2f 92 7b 02 c8 48 51 93 93 82 >...Z`..bB*.+(.X,f^.../.{..HQ...
04a0 df 7d a4 c2 af 7e 79 0c 44 42 62 82 d1 ab 2f 21 8d 52 54 1a ef 83 35 8e 73 df c5 4b 1d 84 d9 27 .}...~y.DBb.../!.RT...5.s..K...'
04c0 f8 20 ef 59 05 19 29 6a 8b 2a 70 b8 28 58 b1 96 8f 5b 61 32 15 f1 82 b5 be b3 1f 23 ee e0 8b 9a ...Y..)j.*p.(X...[a2.......#....
04e0 0d 45 d9 d0 e4 a4 c4 fd ac 68 90 f1 56 71 c1 80 df ff e9 5b 21 52 9c 99 b9 83 ca 8a 0d bc 52 7c .E.......h..Vq.....[!R........R|
0500 ed af 1e f6 0b 1c dc aa a0 b6 ab 63 b0 01 c8 37 c7 ff 3c 8f 67 1c 4e 97 0b 91 90 f1 49 55 12 4d ...........c...7..<.g.N.....IU.M
0520 8a 7c d7 19 f3 18 fb 6a 0c 16 b3 19 7a bd 1e 32 99 0c e5 e5 65 90 cb e5 41 29 f6 fd 06 95 c6 fb .|.....j....z..2....e...A)......
0540 d0 74 44 4b 0f ed 50 52 00 78 f3 dc 24 39 db 31 43 f2 b2 84 2b 78 68 87 92 cd 0f 37 1d a1 49 27 .tDK..PR.x..$9.1C...+xh....7..I'
0560 96 e9 08 be 36 04 80 da 03 4f 53 48 08 74 5a 0d 68 00 e8 b9 d2 03 b3 b9 04 04 84 ad 58 56 96 12 ....6....OSH.tZ.h...........XV..
0580 d3 53 d3 e8 fc d3 f3 c1 77 2b 6e ff bc 14 39 07 e0 0b d7 6e b3 15 ad ad 3d c0 de d0 69 35 f3 c3 .S......w+n...9....n....=...i5..
05a0 cd ed 3f b0 b9 00 42 14 b0 fe e1 ef 52 b5 fa 7e 9e 7e 0c 3e a6 fe 85 06 22 08 18 cd 15 ff d9 6a ..?...B.....R..~.~.>...."......j
05c0 85 67 dc c3 0b 36 3b eb 43 e7 07 75 11 52 8c 05 ea e7 b8 28 17 10 37 df 64 f3 ed 63 c0 f0 48 28 .g...6;.C..u.R.....(..7.d..c..H(
05e0 a8 10 24 0d 00 9d ff ee c4 9f cf 9c 8d 80 24 b5 8f 17 50 69 0a c1 93 d5 2b 83 5f c4 18 e9 8a 7c ..$...........$...Pi....+._....|
0600 60 69 9f bd 2c 58 a1 58 a0 56 cf 23 bc 80 b6 33 47 43 cd e8 ff f9 dc 8a 86 43 d2 00 70 a9 b3 03 `i..,X.X.V.#...3GC.......C..p...
0620 e5 65 a5 70 39 5d f8 fd a9 d7 48 44 05 0f 6e 55 d0 11 b7 1f a9 52 09 a4 ab b7 21 35 35 15 46 e3 .e.p9]....HD..nU.....R....!55.F.
0640 83 bc 60 7b 7e bc 97 30 f9 b1 a4 28 04 6a 75 6f e6 05 3c 5c df c0 ae 2d 04 da d2 bf 0a be af 7d ..`{~..0...(.juo..<\...-.......}
0660 28 2b b5 a0 a4 a4 04 1d 9d 9d 28 2f 2d 85 67 7c 1c 99 72 39 7e fd f2 6f 89 60 0f 36 bc 58 4f db (+........(/-.g|..r9~..o.`.6.XO.
0680 db 6d d8 b9 e3 d1 98 52 64 be 7c 22 a0 f9 e6 9f 08 02 86 af cd 05 b5 8f 52 a8 b3 81 e9 35 47 70 .m.....Rd.|"............R....5Gp
06a0 ec f8 09 14 9b 4c 28 31 15 c3 3f 37 87 59 9f 0f 3d 3d 3d 38 77 fe 23 12 d5 64 6a 6a 76 d1 ea aa .....L(1..?7.Y..===8w.#..djjv...
06c0 2a ac cc 59 19 97 14 13 01 25 da a7 20 64 32 7c f9 0c e8 ce 9f 9f 42 a6 22 33 b8 ee 85 76 64 ab *..Y.....%...d2|......B."3...vd.
06e0 54 98 f5 f9 90 9e 9e 0e a7 d3 85 aa aa 0a 8c 8d 8e e2 99 43 75 24 2e 17 e5 4a 97 ed 51 11 40 63 T..................Cu$...J..Q.@c
0700 b9 68 78 fe db 8d a7 69 34 b0 ea ea 2a 10 10 74 75 77 e3 f8 89 57 48 dc db 84 d8 a0 8c 33 c6 72 .hx....i4...*..tuw...WH......3.r
0720 51 ae 14 e3 05 2b 49 69 e2 dd 5e e2 02 14 1b 54 c8 45 6f 59 8f 61 c4 ed 67 a5 d8 da 6a 45 46 46 Q....+Ii..^....T.EoY.a..g...jEFF
0740 3a 94 2b 56 08 82 f5 5a 5f e7 35 23 89 84 e0 d4 59 37 59 10 a0 58 a0 42 2e 9a ad ca 8e a8 98 ed :.+V...Z_.5#....Y7Y..X.B........
0760 e2 25 6c d8 b0 5e 50 8a e1 66 a4 5d 25 c5 a0 73 0e be af 03 68 e9 b8 85 84 00 63 81 32 52 14 02 .%l..^P..f.]%..s....h.....c.2R..
0780 e5 73 51 1a 00 74 6b b4 21 52 ec e9 e9 81 4e b7 26 42 8a 42 e6 35 e2 f6 c3 33 e1 85 b1 40 89 fb .sQ..tk.!R....N.&B.B.5...3...@..
07a0 b3 53 70 f5 3f 13 77 07 98 68 45 6b 0f 3c 1d 4c 90 10 68 d5 41 40 db 45 1b 2c 66 73 84 14 9b 9b .Sp.?.w..hEk.<.L..h.A@.E.,fs....
07c0 5b a0 52 a9 78 a5 08 00 b6 4f 27 70 ea ac 9b 5d ff c9 4a 05 f5 79 27 f0 97 cb c1 b7 59 a2 00 2e [.R.x....O'p...]..J..y'.....Y...
07e0 14 f4 ed c6 d3 f4 f4 1f 1b 61 2a 2e c6 17 8e 2f 78 c1 f8 a4 c8 1d 18 c2 a5 68 ed 4d 23 0b 1e b6 .........a*..../x........h.M#...
0800 c5 02 b5 8f 06 41 55 e5 0b 73 c5 68 03 c3 8d a1 e9 10 29 be df e6 fd e6 00 85 40 3f 76 fd 00 32 .....AU..s.h......).......@?v..2
0820 99 6c c1 ae 18 8f 14 13 3a 2e 89 0d 2a 5f b3 13 26 53 11 ee dc f1 46 dd a0 b9 ae 1b af 14 17 15 .l......:...*_..&S....F.........
0840 10 00 b4 1a 35 7d e0 81 02 ac 5d 5b 18 97 14 19 d0 1b 43 d3 c8 c9 ca 40 a9 3e 33 aa 14 17 1d 90 ....5}....][......C....@.>3.....
0860 09 a3 f1 21 ba 7d db 56 f4 5a 5f e7 35 a3 70 29 02 c0 a6 07 7d b4 f9 d3 b4 84 7e 3f f3 8d 03 0a ...!.}.V.Z_.5.p)....}.....~?....
0880 f5 68 cd f7 72 ee 4a 8a 4b 12 50 4c 29 0a c5 ff 00 97 bd fa 6f 8f 42 1e e9 00 00 00 00 49 45 4e .h..r.J.K.PL).......o.B......IEN
08a0 44 ae 42 60 82 D.B`.
7 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806
/*
 * Minetest
 * Copyright (C) 2010-2014 celeron55, Perttu Ahola <celeron55@gmail.com>
 * Copyright (C) 2010-2014 kwolekr, Ryan Kwolek <kwolekr@minetest.net>
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification, are
 * permitted provided that the following conditions are met:
 *  1. Redistributions of source code must retain the above copyright notice, this list of
 *     conditions and the following disclaimer.
 *  2. Redistributions in binary form must reproduce the above copyright notice, this list
 *     of conditions and the following disclaimer in the documentation and/or other materials
 *     provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
 * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#include <cmath>
#include "noise.h"
#include <iostream>
#include <cstring> // memset
#include "debug.h"
#include "util/numeric.h"
#include "util/string.h"
#include "exceptions.h"

#define NOISE_MAGIC_X    1619
#define NOISE_MAGIC_Y    31337
#define NOISE_MAGIC_Z    52591
#define NOISE_MAGIC_SEED 1013

typedef float (*Interp2dFxn)(
		float v00, float v10, float v01, float v11,
		float x, float y);

typedef float (*Interp3dFxn)(
		float v000, float v100, float v010, float v110,
		float v001, float v101, float v011, float v111,
		float x, float y, float z);

float cos_lookup[16] = {
	1.0f,  0.9238f,  0.7071f,  0.3826f, .0f, -0.3826f, -0.7071f, -0.9238f,
	1.0f, -0.9238f, -0.7071f, -0.3826f, .0f,  0.3826f,  0.7071f,  0.9238f
};

FlagDesc flagdesc_noiseparams[] = {
	{"defaults",    NOISE_FLAG_DEFAULTS},
	{"eased",       NOISE_FLAG_EASED},
	{"absvalue",    NOISE_FLAG_ABSVALUE},
	{"pointbuffer", NOISE_FLAG_POINTBUFFER},
	{"simplex",     NOISE_FLAG_SIMPLEX},
	{NULL,          0}
};

///////////////////////////////////////////////////////////////////////////////

PcgRandom::PcgRandom(u64 state, u64 seq)
{
	seed(state, seq);
}

void PcgRandom::seed(u64 state, u64 seq)
{
	m_state = 0U;
	m_inc = (seq << 1u) | 1u;
	next();
	m_state += state;
	next();
}


u32 PcgRandom::next()
{
	u64 oldstate = m_state;
	m_state = oldstate * 6364136223846793005ULL + m_inc;

	u32 xorshifted = ((oldstate >> 18u) ^ oldstate) >> 27u;
	u32 rot = oldstate >> 59u;
	return (xorshifted >> rot) | (xorshifted << ((-rot) & 31));
}


u32 PcgRandom::range(u32 bound)
{
	// If the bound is 0, we cover the whole RNG's range
	if (bound == 0)
		return next();

	/*
		This is an optimization of the expression:
		  0x100000000ull % bound
		since 64-bit modulo operations typically much slower than 32.
	*/
	u32 threshold = -bound % bound;
	u32 r;

	/*
		If the bound is not a multiple of the RNG's range, it may cause bias,
		e.g. a RNG has a range from 0 to 3 and we take want a number 0 to 2.
		Using rand() % 3, the number 0 would be twice as likely to appear.
		With a very large RNG range, the effect becomes less prevalent but
		still present.

		This can be solved by modifying the range of the RNG to become a
		multiple of bound by dropping values above the a threshold.

		In our example, threshold == 4 % 3 == 1, so reject values < 1
		(that is, 0), thus making the range == 3 with no bias.

		This loop may look dangerous, but will always terminate due to the
		RNG's property of uniformity.
	*/
	while ((r = next()) < threshold)
		;

	return r % bound;
}


s32 PcgRandom::range(s32 min, s32 max)
{
	if (max < min)
		throw PrngException("Invalid range (max < min)");

	// We have to cast to s64 because otherwise this could overflow,
	// and signed overflow is undefined behavior.
	u32 bound = (s64)max - (s64)min + 1;
	return range(bound) + min;
}


void PcgRandom::bytes(void *out, size_t len)
{
	u8 *outb = (u8 *)out;
	int bytes_left = 0;
	u32 r;

	while (len--) {
		if (bytes_left == 0) {
			bytes_left = sizeof(u32);
			r = next();
		}

		*outb = r & 0xFF;
		outb++;
		bytes_left--;
		r >>= CHAR_BIT;
	}
}


s32 PcgRandom::randNormalDist(s32 min, s32 max, int num_trials)
{
	s32 accum = 0;
	for (int i = 0; i != num_trials; i++)
		accum += range(min, max);
	return myround((float)accum / num_trials);
}

///////////////////////////////////////////////////////////////////////////////

float noise2d(int x, int y, s32 seed)
{
	unsigned int n = (NOISE_MAGIC_X * x + NOISE_MAGIC_Y * y
			+ NOISE_MAGIC_SEED * seed) & 0x7fffffff;
	n = (n >> 13) ^ n;
	n = (n * (n * n * 60493 + 19990303) + 1376312589) & 0x7fffffff;
	return 1.f - (float)(int)n / 0x40000000;
}


float noise3d(int x, int y, int z, s32 seed)
{
	unsigned int n = (NOISE_MAGIC_X * x + NOISE_MAGIC_Y * y + NOISE_MAGIC_Z * z
			+ NOISE_MAGIC_SEED * seed) & 0x7fffffff;
	n = (n >> 13) ^ n;
	n = (n * (n * n * 60493 + 19990303) + 1376312589) & 0x7fffffff;
	return 1.f - (float)(int)n / 0x40000000;
}


inline float dotProduct(float vx, float vy, float wx, float wy)
{
	return vx * wx + vy * wy;
}


inline float linearInterpolation(float v0, float v1, float t)
{
	return v0 + (v1 - v0) * t;
}


inline float biLinearInterpolation(
	float v00, float v10,
	float v01, float v11,
	float x, float y)
{
	float tx = easeCurve(x);
	float ty = easeCurve(y);
	float u = linearInterpolation(v00, v10, tx);
	float v = linearInterpolation(v01, v11, tx);
	return linearInterpolation(u, v, ty);
}


inline float biLinearInterpolationNoEase(
	float v00, float v10,
	float v01, float v11,
	float x, float y)
{
	float u = linearInterpolation(v00, v10, x);
	float v = linearInterpolation(v01, v11, x);
	return linearInterpolation(u, v, y);
}


float triLinearInterpolation(
	float v000, float v100, float v010, float v110,
	float v001, float v101, float v011, float v111,
	float x, float y, float z)
{
	float tx = easeCurve(x);
	float ty = easeCurve(y);
	float tz = easeCurve(z);
	float u = biLinearInterpolationNoEase(v000, v100, v010, v110, tx, ty);
	float v = biLinearInterpolationNoEase(v001, v101, v011, v111, tx, ty);
	return linearInterpolation(u, v, tz);
}

float triLinearInterpolationNoEase(
	float v000, float v100, float v010, float v110,
	float v001, float v101, float v011, float v111,
	float x, float y, float z)
{