文档库 最新最全的文档下载
当前位置:文档库 › 用verilog写的正弦波发生器

用verilog写的正弦波发生器

module sin(clk,rst_n,clock_1,addr_div_1,sin_data);

input clk;
input rst_n;

output[9:0] sin_data;
output[9:0] addr_div_1;
//output[9:0] addr_div;

output clock_1;

wire clock;
wire[9:0] addr_div;
wire[9:0] address;
wire[9:0] line;
//wire[7:0] q;
//wire[9:0] cnt_temp;

div U1(
.clk(clk),
.rst_n(rst_n),
.clock_1(clock_1),
.clock(clock)
);

counter U2(
.clock(clock),
.rst_n(rst_n),
.addr_div_1(addr_div_1),
.addr_div(line)
);

sinwave U3(
.clock(clock),
.address(line),
.q(sin_data)
);

endmodule


module div(clk,rst_n,clock,clock_1);

input clk;
input rst_n;

output clock;
output clock_1;

reg[9:0] count;
reg[9:0] count_temp;

always@(posedge clk or negedge rst_n)
begin
if(!rst_n)
begin
count <= 10'd0;
count_temp=0;
end
else if(count == 10'd24)
begin
count <= 10'd0;
count_temp <= ~count_temp;
end
else
begin
count <= count + 10'd1;
end
end
wire clock,clock_1;
assign clock = count_temp;
assign clock_1 = count_temp;

endmodule


module counter(clock,rst_n,addr_div,addr_div_1);

input clock;
input rst_n;

output[9:0] addr_div;
output[9:0] addr_div_1;

reg[9:0] cnt;
reg[9:0] cnt_temp;

always@(posedge clock or negedge rst_n)
if(!rst_n)
cnt <= 10'd0;
else if(cnt == 10'd1023) cnt <= 10'd0;
else
cnt <= cnt + 10'd1;

always@(posedge clock or negedge rst_n)
if(!rst_n)
cnt_temp <= 10'd0;
else if(cnt == 10'd1023)
cnt_temp <= 10'd0;
else
cnt_temp <= cnt;



wire[9:0] addr_div,addr_div_1;
assign addr_div = cnt_temp;
assign addr_div_1 = cnt_temp;

endmodule

//正弦波形数据,做ROM用
WIDTH=10;
DEPTH=1024;

ADDRESS_RADIX=UNS;
DATA_RADIX=UNS;

CONTENT BEGIN
0 : 511;
1 : 514;
2 : 517;
3 : 520;
4 : 524;
5 : 527;
6 : 530;
7 : 533;
8 : 536;
9 : 539;
10 : 542;
11 : 545;
12 : 549;
13 : 552;
14 : 555;
15 : 558;
16 : 561;
17 : 564;
18 : 567;
19 : 570;
20 : 574;
21 : 577;
22 : 580;
23 : 583;
24 : 586;
25 : 589;
26 : 592;
27 : 595;
28 : 598;
29 : 602;
30 : 605;
31 : 608;
32 : 611;
33 : 614;
34 : 617;
35 : 620;
36 : 623;
37 : 626;
38 : 629;
39 : 632;
40 : 635;
41 : 638;
42 : 641;
43 : 644;
44 : 647;
45 : 650;
46 : 653;
47 : 656;
48 : 659;
49 : 662;
50 : 665;
51 : 668;
52 : 671;
53 : 674;
54 : 677;
55 : 680;
56 : 683;
57 : 686;
58 : 689;
59 : 692;
60 :

695;
61 : 698;
62 : 701;
63 : 704;
64 : 707;
65 : 710;
66 : 713;
67 : 715;
68 : 718;
69 : 721;
70 : 724;
71 : 727;
72 : 730;
73 : 733;
74 : 735;
75 : 738;
76 : 741;
77 : 744;
78 : 747;
79 : 749;
80 : 752;
81 : 755;
82 : 758;
83 : 760;
84 : 763;
85 : 766;
86 : 769;
87 : 771;
88 : 774;
89 : 777;
90 : 779;
91 : 782;
92 : 785;
93 : 787;
94 : 790;
95 : 793;
96 : 795;
97 : 798;
98 : 800;
99 : 803;
100 : 806;
101 : 808;
102 : 811;
103 : 813;
104 : 816;
105 : 818;
106 : 821;
107 : 823;
108 : 826;
109 : 828;
110 : 831;
111 : 833;
112 : 835;
113 : 838;
114 : 840;
115 : 843;
116 : 845;
117 : 847;
118 : 850;
119 : 852;
120 : 855;
121 : 857;
122 : 859;
123 : 861;
124 : 864;
125 : 866;
126 : 868;
127 : 870;
128 : 873;
129 : 875;
130 : 877;
131 : 879;
132 : 881;
133 : 884;
134 : 886;
135 : 888;
136 : 890;
137 : 892;
138 : 894;
139 : 896;
140 : 898;
141 : 900;
142 : 902;
143 : 904;
144 : 906;
145 : 908;
146 : 910;
147 : 912;
148 : 914;
149 : 916;
150 : 918;
151 : 920;
152 : 922;
153 : 924;
154 : 926;
155 : 927;
156 : 929;
157 : 931;
158 : 933;
159 : 935;
160 : 936;
161 : 938;
162 : 940;
163 : 941;
164 : 943;
165 : 945;
166 : 946;
167 : 948;
168 : 950;
169 : 951;
170 : 953;
171 : 954;
172 : 956;
173 : 958;
174 : 959;
175 : 961;
176 : 962;
177 : 964;
178 : 965;
179 : 966;
180 : 968;
181 : 969;
182 : 971;
183 : 972;
184 : 973;
185 : 975;
186 : 976;
187 : 977;
188 : 979;
189 : 980;
190 : 981;
191 : 982;
192 : 984;
193 : 985;
194 : 986;
195 : 987;
196 : 988;
197 : 989;
198 : 990;
199 : 992;
200 : 993;
201 : 994;
202 : 995;
203 : 996;
204 : 997;
205 : 998;
206 : 999;
207 : 1000;
208 : 1000;
209 : 1001;
210 : 1002;
211 : 1003;
212

: 1004;
213 : 1005;
214 : 1006;
215 : 1006;
216 : 1007;
217 : 1008;
218 : 1009;
219 : 1009;
220 : 1010;
221 : 1011;
222 : 1011;
223 : 1012;
224 : 1013;
225 : 1013;
226 : 1014;
227 : 1014;
228 : 1015;
229 : 1015;
230 : 1016;
231 : 1016;
232 : 1017;
233 : 1017;
234 : 1018;
235 : 1018;
236 : 1019;
237 : 1019;
238 : 1019;
239 : 1020;
240 : 1020;
241 : 1020;
242 : 1021;
243 : 1021;
244 : 1021;
245 : 1021;
246 : 1022;
247 : 1022;
248 : 1022;
249 : 1022;
250 : 1022;
251 : 1022;
252 : 1022;
253 : 1022;
254 : 1022;
255 : 1022;
256 : 1023;
257 : 1022;
258 : 1022;
259 : 1022;
260 : 1022;
261 : 1022;
262 : 1022;
263 : 1022;
264 : 1022;
265 : 1022;
266 : 1022;
267 : 1021;
268 : 1021;
269 : 1021;
270 : 1021;
271 : 1020;
272 : 1020;
273 : 1020;
274 : 1019;
275 : 1019;
276 : 1019;
277 : 1018;
278 : 1018;
279 : 1017;
280 : 1017;
281 : 1016;
282 : 1016;
283 : 1015;
284 : 1015;
285 : 1014;
286 : 1014;
287 : 1013;
288 : 1013;
289 : 1012;
290 : 1011;
291 : 1011;
292 : 1010;
293 : 1009;
294 : 1009;
295 : 1008;
296 : 1007;
297 : 1006;
298 : 1006;
299 : 1005;
300 : 1004;
301 : 1003;
302 : 1002;
303 : 1001;
304 : 1000;
305 : 1000;
306 : 999;
307 : 998;
308 : 997;
309 : 996;
310 : 995;
311 : 994;
312 : 993;
313 : 992;
314 : 990;
315 : 989;
316 : 988;
317 : 987;
318 : 986;
319 : 985;
320 : 984;
321 : 982;
322 : 981;
323 : 980;
324 : 979;
325 : 977;
326 : 976;
327 : 975;
328 : 973;
329 : 972;
330 : 971;
331 : 969;
332 : 968;
333 : 966;
334 : 965;
335 : 964;
336 : 962;
337 : 961;
338 : 959;
339 : 958;
340 : 956;
341 : 954;
342 : 953;
343 : 951;
344 : 950;
345 : 948;
346 : 946;
347 : 945;
348 : 943;
349 : 941;
350 : 940;
351 : 938;
352 : 936;
353 : 935;
354 : 933;
355 : 931;
356 : 929;
357 :

927;
358 : 926;
359 : 924;
360 : 922;
361 : 920;
362 : 918;
363 : 916;
364 : 914;
365 : 912;
366 : 910;
367 : 908;
368 : 906;
369 : 904;
370 : 902;
371 : 900;
372 : 898;
373 : 896;
374 : 894;
375 : 892;
376 : 890;
377 : 888;
378 : 886;
379 : 884;
380 : 881;
381 : 879;
382 : 877;
383 : 875;
384 : 873;
385 : 870;
386 : 868;
387 : 866;
388 : 864;
389 : 861;
390 : 859;
391 : 857;
392 : 855;
393 : 852;
394 : 850;
395 : 847;
396 : 845;
397 : 843;
398 : 840;
399 : 838;
400 : 835;
401 : 833;
402 : 831;
403 : 828;
404 : 826;
405 : 823;
406 : 821;
407 : 818;
408 : 816;
409 : 813;
410 : 811;
411 : 808;
412 : 806;
413 : 803;
414 : 800;
415 : 798;
416 : 795;
417 : 793;
418 : 790;
419 : 787;
420 : 785;
421 : 782;
422 : 779;
423 : 777;
424 : 774;
425 : 771;
426 : 769;
427 : 766;
428 : 763;
429 : 760;
430 : 758;
431 : 755;
432 : 752;
433 : 749;
434 : 747;
435 : 744;
436 : 741;
437 : 738;
438 : 735;
439 : 733;
440 : 730;
441 : 727;
442 : 724;
443 : 721;
444 : 718;
445 : 715;
446 : 713;
447 : 710;
448 : 707;
449 : 704;
450 : 701;
451 : 698;
452 : 695;
453 : 692;
454 : 689;
455 : 686;
456 : 683;
457 : 680;
458 : 677;
459 : 674;
460 : 671;
461 : 668;
462 : 665;
463 : 662;
464 : 659;
465 : 656;
466 : 653;
467 : 650;
468 : 647;
469 : 644;
470 : 641;
471 : 638;
472 : 635;
473 : 632;
474 : 629;
475 : 626;
476 : 623;
477 : 620;
478 : 617;
479 : 614;
480 : 611;
481 : 608;
482 : 605;
483 : 602;
484 : 598;
485 : 595;
486 : 592;
487 : 589;
488 : 586;
489 : 583;
490 : 580;
491 : 577;
492 : 574;
493 : 570;
494 : 567;
495 : 564;
496 : 561;
497 : 558;
498 : 555;
499 : 552;
500 : 549;
501 : 545;
502 : 542;
503 : 539;
504 : 536;
505 : 533;
506 : 530;
507 :

527;
508 : 524;
509 : 520;
510 : 517;
511 : 514;
512 : 511;
513 : 508;
514 : 505;
515 : 502;
516 : 498;
517 : 495;
518 : 492;
519 : 489;
520 : 486;
521 : 483;
522 : 480;
523 : 477;
524 : 473;
525 : 470;
526 : 467;
527 : 464;
528 : 461;
529 : 458;
530 : 455;
531 : 452;
532 : 448;
533 : 445;
534 : 442;
535 : 439;
536 : 436;
537 : 433;
538 : 430;
539 : 427;
540 : 424;
541 : 420;
542 : 417;
543 : 414;
544 : 411;
545 : 408;
546 : 405;
547 : 402;
548 : 399;
549 : 396;
550 : 393;
551 : 390;
552 : 387;
553 : 384;
554 : 381;
555 : 378;
556 : 375;
557 : 372;
558 : 369;
559 : 366;
560 : 363;
561 : 360;
562 : 357;
563 : 354;
564 : 351;
565 : 348;
566 : 345;
567 : 342;
568 : 339;
569 : 336;
570 : 333;
571 : 330;
572 : 327;
573 : 324;
574 : 321;
575 : 318;
576 : 315;
577 : 312;
578 : 309;
579 : 307;
580 : 304;
581 : 301;
582 : 298;
583 : 295;
584 : 292;
585 : 289;
586 : 287;
587 : 284;
588 : 281;
589 : 278;
590 : 275;
591 : 273;
592 : 270;
593 : 267;
594 : 264;
595 : 262;
596 : 259;
597 : 256;
598 : 253;
599 : 251;
600 : 248;
601 : 245;
602 : 243;
603 : 240;
604 : 237;
605 : 235;
606 : 232;
607 : 229;
608 : 227;
609 : 224;
610 : 222;
611 : 219;
612 : 216;
613 : 214;
614 : 211;
615 : 209;
616 : 206;
617 : 204;
618 : 201;
619 : 199;
620 : 196;
621 : 194;
622 : 191;
623 : 189;
624 : 187;
625 : 184;
626 : 182;
627 : 179;
628 : 177;
629 : 175;
630 : 172;
631 : 170;
632 : 167;
633 : 165;
634 : 163;
635 : 161;
636 : 158;
637 : 156;
638 : 154;
639 : 152;
640 : 149;
641 : 147;
642 : 145;
643 : 143;
644 : 141;
645 : 138;
646 : 136;
647 : 134;
648 : 132;
649 : 130;
650 : 128;
651 : 126;
652 : 124;
653 : 122;
654 : 120;
655 : 118;
656 : 116;
657 :

114;
658 : 112;
659 : 110;
660 : 108;
661 : 106;
662 : 104;
663 : 102;
664 : 100;
665 : 98;
666 : 96;
667 : 95;
668 : 93;
669 : 91;
670 : 89;
671 : 87;
672 : 86;
673 : 84;
674 : 82;
675 : 81;
676 : 79;
677 : 77;
678 : 76;
679 : 74;
680 : 72;
681 : 71;
682 : 69;
683 : 68;
684 : 66;
685 : 64;
686 : 63;
687 : 61;
688 : 60;
689 : 58;
690 : 57;
691 : 56;
692 : 54;
693 : 53;
694 : 51;
695 : 50;
696 : 49;
697 : 47;
698 : 46;
699 : 45;
700 : 43;
701 : 42;
702 : 41;
703 : 40;
704 : 38;
705 : 37;
706 : 36;
707 : 35;
708 : 34;
709 : 33;
710 : 32;
711 : 30;
712 : 29;
713 : 28;
714 : 27;
715 : 26;
716 : 25;
717 : 24;
718 : 23;
719 : 22;
720 : 22;
721 : 21;
722 : 20;
723 : 19;
724 : 18;
725 : 17;
726 : 16;
727 : 16;
728 : 15;
729 : 14;
730 : 13;
731 : 13;
732 : 12;
733 : 11;
734 : 11;
735 : 10;
736 : 9;
737 : 9;
738 : 8;
739 : 8;
740 : 7;
741 : 7;
742 : 6;
743 : 6;
744 : 5;
745 : 5;
746 : 4;
747 : 4;
748 : 3;
749 : 3;
750 : 3;
751 : 2;
752 : 2;
753 : 2;
754 : 1;
755 : 1;
756 : 1;
757 : 1;
758 : 0;
759 : 0;
760 : 0;
761 : 0;
762 : 0;
763 : 0;
764 : 0;
765 : 0;
766 : 0;
767 : 0;
768 : 0;
769 : 0;
770 : 0;
771 : 0;
772 : 0;
773 : 0;
774 : 0;
775 : 0;
776 : 0;
777 : 0;
778 : 0;
779 : 1;
780 : 1;
781 : 1;
782 : 1;
783 : 2;
784 : 2;
785 : 2;
786 : 3;
787 : 3;
788 : 3;
789 : 4;
790 : 4;
791 : 5;
792 : 5;
793 : 6;
794 : 6;
795 : 7;
796 : 7;
797 : 8;
798 : 8;
799 : 9;
800 : 9;
801 : 10;
802 : 11;
803 : 11;
804 : 12;
805 : 13;
806 : 13;
807 : 14;
808 : 15;
809 : 16;
810 : 16;
811 : 17;
812 : 18;
813 : 19;
814 : 20;
815 : 21;
816 : 22;
817 : 22;
818

: 23;
819 : 24;
820 : 25;
821 : 26;
822 : 27;
823 : 28;
824 : 29;
825 : 30;
826 : 32;
827 : 33;
828 : 34;
829 : 35;
830 : 36;
831 : 37;
832 : 38;
833 : 40;
834 : 41;
835 : 42;
836 : 43;
837 : 45;
838 : 46;
839 : 47;
840 : 49;
841 : 50;
842 : 51;
843 : 53;
844 : 54;
845 : 56;
846 : 57;
847 : 58;
848 : 60;
849 : 61;
850 : 63;
851 : 64;
852 : 66;
853 : 68;
854 : 69;
855 : 71;
856 : 72;
857 : 74;
858 : 76;
859 : 77;
860 : 79;
861 : 81;
862 : 82;
863 : 84;
864 : 86;
865 : 87;
866 : 89;
867 : 91;
868 : 93;
869 : 95;
870 : 96;
871 : 98;
872 : 100;
873 : 102;
874 : 104;
875 : 106;
876 : 108;
877 : 110;
878 : 112;
879 : 114;
880 : 116;
881 : 118;
882 : 120;
883 : 122;
884 : 124;
885 : 126;
886 : 128;
887 : 130;
888 : 132;
889 : 134;
890 : 136;
891 : 138;
892 : 141;
893 : 143;
894 : 145;
895 : 147;
896 : 149;
897 : 152;
898 : 154;
899 : 156;
900 : 158;
901 : 161;
902 : 163;
903 : 165;
904 : 167;
905 : 170;
906 : 172;
907 : 175;
908 : 177;
909 : 179;
910 : 182;
911 : 184;
912 : 187;
913 : 189;
914 : 191;
915 : 194;
916 : 196;
917 : 199;
918 : 201;
919 : 204;
920 : 206;
921 : 209;
922 : 211;
923 : 214;
924 : 216;
925 : 219;
926 : 222;
927 : 224;
928 : 227;
929 : 229;
930 : 232;
931 : 235;
932 : 237;
933 : 240;
934 : 243;
935 : 245;
936 : 248;
937 : 251;
938 : 253;
939 : 256;
940 : 259;
941 : 262;
942 : 264;
943 : 267;
944 : 270;
945 : 273;
946 : 275;
947 : 278;
948 : 281;
949 : 284;
950 : 287;
951 : 289;
952 : 292;
953 : 295;
954 : 298;
955 : 301;
956 : 304;
957 : 307;
958 : 309;
959 : 312;
960 : 315;
961 : 318;
962 : 321;
963 : 324;
964 : 327;
965 : 330;
966 : 333;
967 : 336;
968 : 339;
969 : 342;
970 : 345;
9

71 : 348;
972 : 351;
973 : 354;
974 : 357;
975 : 360;
976 : 363;
977 : 366;
978 : 369;
979 : 372;
980 : 375;
981 : 378;
982 : 381;
983 : 384;
984 : 387;
985 : 390;
986 : 393;
987 : 396;
988 : 399;
989 : 402;
990 : 405;
991 : 408;
992 : 411;
993 : 414;
994 : 417;
995 : 420;
996 : 424;
997 : 427;
998 : 430;
999 : 433;
1000 : 436;
1001 : 439;
1002 : 442;
1003 : 445;
1004 : 448;
1005 : 452;
1006 : 455;
1007 : 458;
1008 : 461;
1009 : 464;
1010 : 467;
1011 : 470;
1012 : 473;
1013 : 477;
1014 : 480;
1015 : 483;
1016 : 486;
1017 : 489;
1018 : 492;
1019 : 495;
1020 : 498;
1021 : 502;
1022 : 505;
1023 : 508;
END;

相关文档
相关文档 最新文档