

Aim:- To design and simulate the layout of NMOS inverter.

Software required :- Microwind

Procedure:-

- ① Select a new boundary by clicking on file, select foundry.
- ② Fix the left corner to be  $1\lambda = 0.06\mu m$ .
- ③ Select the metal 1 layer from the palette to create metal layer of width  $4\lambda$ .
- ④ Select the p+ diffusion intersecting metal layer down of width  $4\lambda$ .
- ⑤ Draw a metal layer intersecting the p+ diffusion.
- ⑥ Place the polysilicon layer for the gate on P+ diffusion as well as on N+ diffusion & connect both gate polysilicon.
- ⑦ Draw the metal layer at the other end of the n+ diffusion layer and assign a ground to it.
- ⑧ Give the required contacts such as metal to n+ diffusion, P+ diffusion to metal.
- ⑨ Assign the Vdd supply to the upper metal layer of P+ diffusion.
- ⑩ Assign the input clock pulse to the gate of amplitude equal to 0V to 5V.
- ⑪ Assign the visible node as the output.
- ⑫ Check for any errors using DRC.
- ⑬ Save and simulate to get the required output waveform.

Diagram :-

Circuit diagram



Switch Analogy



Symbol



Truth Table

| A | B |
|---|---|
| 0 | 1 |
| 1 | 0 |



VTC

## Theory:-

The logic symbol and truth table of ideal inverter is shown in figure.

Using positive logic, the Boolean value of logic 1 is represented by  $V_{DD}$  & logic 0 is represented by 0.

$V_{th}$  is the inverter threshold voltage, which is  $V_{DD}/2$  where  $V_{DD}$  is the output voltage.

So for  $0 < V_{in} < V_{th}$  output is equal to logic 0 input and  $V_{th} < V_{in} < V_{DD}$  is equal to logic 1 input for inverter.

## Case 1:-

When logic '0' is applied to input, switch ' $S_1$ ' stays close & switch ' $S_2$ ' is open. Thus whole charge flows towards,  $V_{DD}$ , thus the charge is pull up with logic at output end is '1'.

## Case 2:-

When logic '1' is applied to input, switch ' $S_1$ ' stays close and switch ' $S_2$ ' is also closed. Thus the whole charge flows towards ground ' $V_{SS}$ ' thus the charge is pull down with logic at output end is '0'.

## Result:-

Thus we have designed, implemented and simulated the layout of the NMOS inverter using Microwind. The output voltage does not reach 5 volt during logic high, because  $W/L$  ratio of pullup & pulldown are not appropriately set. The VTC is also not sharp which is a limitation.

Microwind Ver 3.0 - Example.msk

View Edit Simulate Compile Analysis Help





Prim :- To design and simulate the layout of CMOS inverter.

Software required :- Microwind

Procedure :-

- (1) Select a new foundry by clicking on file, select foundry, CMOS 012.rul.
- (2) Fix the left corner to be  $1\lambda = 0.06 \mu\text{m}$ .
- (3) Select the metal 1 layer from the palette to create metal layer of width  $4\lambda$ .
- (4) Select the  $p^+$  diffusion intersecting metal layer down of width  $4\lambda$ .
- (5) Draw a metal layer intersecting the  $p^+$  diffusion.
- (6) Now draw the n well of area  $144 \lambda^2$  around the  $p^+$  diffusion area so that there will be min.
- (7) Now draw the  $n^+$  diffusion below the n well, such that there is at least  $6\lambda$  separation.
- (8) Now connect the  $p^+$  diffusion layers other end with the  $n^+$  diffusion one end by metal layer and draw the metal layer outside which is output.
- (9) Place the polysilicon layer for the gate on  $p^+$  diffusion as well as on  $n^+$  diffusion and connect both gates polysilicon.
- (10) Draw the metal layer at the other end of the  $n^+$  diffusion layer and assign a ground to it.
- (11) Give the required contacts such as metal to  $n^+$  diffusion,  $p^+$  diffusion to metal.
- (12) Assign the Vdd supply to the upper metal layer of  $p^+$  diffusion.
- (13) Give Vdd supply to the n well, because it is required not to leave it floating.

## Circuit Diagram



Switch Analogy



Symbol

Truth Table

| Input | Output |
|-------|--------|
| 1     | 0      |
| 0     | 1      |

- (14) Assign the input clock pulse to the gate of amplitude equal to 0V to 5V.
- (15) Assign the visible node as the output to the CMOS at both the drains connected.
- (16) Check for any errors using DRC.
- (17) Save and simulate to get the required output waveforms.

### Theory:-

① When the low input voltage is given to the CMOS inverter, then the PMOS transistor is switched ON, whereas the NMOS transistor will switch OFF by allowing the flow of electrons throughout the gate terminal and generally high logic output voltage.

② Similarly, when high input voltage is given to the CMOS inverter, the PMOS transistor is switched OFF whereas the NMOS transistor will be switched ON avoiding as many electrons from attaining the output voltage and generally low logic output.

Thus, direct current supply from the supply voltage ( $V_{DD}$ ) to output voltage ( $V_{OUT}$ ) and the load capacitor ( $C_L$ ) can be charged & shows that  $V_{OUT} = V_{DD}$ .

Result:- Thus we have designed, implemented & simulated the layout of the CMOS inverter using microwind. The output voltage does not reach 5volts during logic high because W/L Ratio of Pull up & pull down are not appropriately set. The VTC is also shown up as compared to NMOS inverter.



Temperature 22.0°C

Chucks 0.1mm - 0.5mm (1.20W, 2.80W)

1.38 2.05 V

Aim - To design and simulate the layout of 2 input CMOS ~~NAND~~ <sup>and</sup> NOR Gate.

Software required - Microwind

Procedure :-

- 1) Select a new Foundary by clicking on fire, select foundry, CMOS 012.rul.
- 2) Fix the left corner to be  $1\lambda = 0.06 \mu\text{m}$ .
- 3) Select the Metal layer from the Palette to create layer of width  $4\lambda$ .
- 4) Select the P+ diffusion intersecting metal layer down of width  $4\lambda$  such that for NAND gate there will be two parallel P+ diffusions for PMOS or single P+ diffusion sufficient for two PMOS for NOR gate.
- 5) Draw a metal layer intersecting the p+ diffusion for Vdd supply.
- 6) Now draw the n well of area  $144\lambda^2$  around the P+ diffusion area so that there will be min  $6\lambda$  separation P+ between P+ diffusion & n well boundary.
- 7) Now draw the n+ diffusion below the n well, such that there is at least  $6\lambda$  separation: NAND gate take single n+ diffusion for two nmos or two parallel diffusion for NOR gate.
- 8) Now connect the P+ diffusion layer other end with the n+ diffusion are one end by metal layer and draw the metal layer outside which is output.
- 9) Place the Polysilicon layer for the gate on P+ diffusion as well as on N+ diffusion & connect both gates polysilicon.
- 10). Draw the metal layer at the other end of the n+ diffusion layer & assign a ground to it.

## CIRCUIT DIAGRAM:- NAND Gate



Case I :  $A=0 \& B=0$



## NAND Gate



## Truth Table

| A | B | Y |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

case II :  $A=0 \& B=1$



Case III :  $A=1 \& B=0$



Case IV :  $A=1 \& B=1$



- 11) Assign the Vdd supply to the upper metal layer of P+ diffusion.
- 12) Give Vdd supply to the upper n well, because it is required not to leave it floating.
- 13) Give the required contacts such as metal to n+ diffusion, P+ diffusion to metal.
- 14) Assign the two input clock pulse to the required gates of the required MOS of amplitude equal to 0V to 5V.
- 15) Assign the visible node as the output to the output metal drawn outside.
- 16) Check for any error using DRC.
- 17) Save and simulate to get the required output waveform.

### Theory - NAND Gate

To understand how this circuit will behave like NAND gate, circuit output follows the same as in truth table for different input combinations.

Case 1 :- A = Low & B = Low, Y = High

- 1) Both the PMOS will be ON and both NMOS will be OFF.
- 2) The output  $V_{out}$  will get two paths through two ON PMOS to get connected with Vdd.
- 3) There is no path through which the output line can discharge.
- 4) The output line will maintain the voltage level at Vdd so high(logic 1).

Case 2 - A = Low & B = High, Y = High

- 1) A = Low, PMOS 1 = ON, NMOS 1 = OFF
- 2) B = High, PMOS 2 = OFF, NMOS 2 = ON
- 3) PMOS 1 & PMOS 2 are in parallel, NMOS 1 & NMOS 2 are in series.

- 3) The output line will get a path through  $\text{Pmos}_2$  to get connected with  $V_{dd}$ .
- 4) The  $V_{out}$  is maintained at the level of  $V_{dd}$  as  $\text{Nmos}_1$  is OFF, so High (Logic 1)

Case 3 -  $A = \text{High}$  &  $B = \text{Low}$ ,  $Y = \text{High}$

- 1)  $A = \text{High}$ ,  $\text{Pmos}_1 = \text{OFF}$ ,  $\text{Nmos}_1 = \text{ON}$   
 $B = \text{Low}$ ,  $\text{Pmos}_2 = \text{ON}$ ,  $\text{Nmos}_2 = \text{OFF}$
- 2)  $\text{PMOS}_1$  &  $\text{PMOS}_2$  are in parallel,  $\text{NMOS}_1$  &  $\text{NMOS}_2$  are in series.
- 3) The output line will get a path through  $\text{PMOS}_2$  to get connected with  $V_{dd}$ .
- 4) The  $V_{out}$  is maintained at the level of  $V_{dd}$  as  $\text{NMOS}_1$  is OFF, so High (Logic 1).

Case 4 -  $A = \text{High}$  &  $B = \text{High}$ ,  $Y = \text{Low}$ .

- 1)  $A = \text{High}$ ,  $\text{Pmos}_1 = \text{OFF}$ ,  $\text{Nmos}_1 = \text{ON}$ .  
 $B = \text{High}$ ,  $\text{Pmos}_2 = \text{OFF}$ ,  $\text{Nmos}_2 = \text{ON}$ .
- 2) Both PMOS are OFF, so  $V_{out}$  will not find any path to get connected with  $V_{dd}$ .
- 3) Both NMOS are ON in series, so it will create a path from  $V_{out}$  to GND.
- 4) Since, Path to ground is established,  $V_{out}$  will be discharged so low. (Logic 0)

# CIRCUIT Diagram: NOR gate.



## NOR GATE



## TRUTH TABLE :-

| A | B | Y |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 0 |

Case I:  $A=0 \& B=0$



Case II:  $A=0 \& B=1$



Case III:  $A=1 \& B=0$



Case IV:  $A=1 \& B=1$



## NOR GATE.

Case 1- A = Low & B = Low, Y = High

- ① As A & B both are low both PMOS's will be 'ON' and both NMOS will be 'OFF'.
- ② Both PMOS get connected to Vdd & As both NMOS are OFF,  $V_{out}$  will not be able to find a path to GND to get discharged.
- ③ This twins  $V_{out}$  to be maintained as a level of Vdd; so logic High (logic 1).

Case 2- A = low & B = High, Y = High.

- ① A - Low - PMOS1 = ON, NMOS1 = OFF
- B - High - PMOS2 = OFF, NMOS2 = ON
- ③ As PMOS2 is OFF the Vdd will not be able to find Path to pass charge towards  $V_{out}$ .
- ③ This twins  $V_{out}$  to be maintained as a level of Vdd; so logic High (logic 1).

Case -3 - A = High & B = Low, Y = low.

- ① As A - High = PMOS1 = OFF, NMOS1 = ON
- B - Low = PMOS2 = ON, NMOS2 = OFF
- ③ PMOS1 is OFF Vdd does not have a path to transfer charge further.
- ③ NMOS1 is ON thus  $V_{out}$  has a path toward GND.
- ③ Thus turn  $V_{out}$  at a level of GND so logic low (logic 0).

Case 4 - A = High & B = High, Y = Low.

- 1) A - High, PMOS1 = OFF, NMOS1 = ON.
- 2) B - High, PMOS2 = OFF, NMOS2 = ON.
- 3) Both PMOS are OFF so V<sub>out</sub> will not find any path to get connected with V<sub>dd</sub>.
- 4) Both NMOS are ON. V<sub>out</sub> finds then path to GND to get discharge.
- 5) This turns V<sub>out</sub> at a level of GND, so logic low (logic 0).

Result:- Thus in this way we have studied, designed, implemented & simulated the layout of NAND & NOR gate using CMOS.





Aim :- To design and simulate the layout of the Boolean function  $F = A(\bar{B} + C)$  using CMOS.

Software Required :- Microwind.

Procedure :-

- ① Select a new foundary by clicking on file, select foundary, CMOS 012 nul.
- ② Fix the left corner to be  $1\lambda = 0.06\text{mm}$ .
- ③ Select metal 1 layer from the palette to create metal layer of width  $4\lambda$ .
- ④ Select the P+ diffusion intersecting metal layer down of width  $4\lambda$  such that to make the required PMOS.
- ⑤ Draw a metal layer intersecting the P+ diffusion which is for Vdd supply.
- ⑥ Draw n well of area  $144\lambda^2$  around the P+ diffusion area so that there will be minimum  $6\lambda$  separation between it diffusion and nwell boundary.
- ⑦ Now draw n+ diffusion below the n well, such that there is at least  $6\lambda$  separation for the required NMOS's.
- ⑧ Now connect the P+ diffusion layers other end with the n+diffusion one end by metal layer and draw the metal layer outside which is output.
- ⑨ Place the polysilicon layer for the gate on P+ diffusion of the required PMOS as well as on N+ diffusion for the required NMOS's and connect gates polysilicon as per requirement.
- ⑩ Draw the metal layer at the other end of the n+diffusion layer and assign a ground to it.
- ⑪ Give required contacts such as metal to ~~n+~~ n+ diffusion, P+diffusion to metal.

# CIRCUIT DIAGRAM

$$\textcircled{i} \quad Y = \overline{A(B+C)}$$



LOGIC GATE

$$\begin{matrix} A \\ B \\ C \end{matrix}$$

$$(B+C) = X$$

TRUTH TABLE: (i) For NAND GATE

| A | B | C | $(B+C) = X$ | $Y = \overline{A \cdot (B+C)}$ |
|---|---|---|-------------|--------------------------------|
| 0 | 0 | 0 | 0           | 1                              |
| 0 | 0 | 1 | 1           | 1                              |
| 0 | 1 | 0 | 1           | 1                              |
| 0 | 1 | 1 | 1           | 1                              |
| 1 | 0 | 0 | 0           | 1                              |
| 1 | 0 | 1 | 1           | 0                              |
| 1 | 1 | 0 | 1           | 0                              |
| 1 | 1 | 1 | 1           | 0                              |

## (ii) OR Gate



## (ii) FOR OR GATE

| B | C | $X = \overline{B+C}$ |
|---|---|----------------------|
| 0 | 0 | 0                    |
| 0 | 1 | 1                    |
| 1 | 0 | 1                    |
| 1 | 1 | 1                    |

## (ii) NAND GATE :-



- ⑫ Assign the  $V_{dd}$  supply to the upper metal & layer of Pt diffusion.
- ⑬ Give  $V_{dd}$  supply to the n-well, because it is required not to leave it floating.
- ⑭ Assign the input clock pulses to the required gate of the required MOS; of amplitude equal to 0V to 5V.
- ⑮ Assign the visible node as the output to the output metal drawn outside.
- ⑯ Check for any error using DRC.
- ⑰ Save and simulate to get the required output waveform.

Theory :-

→ As we could see in logic gate diagram and truth table that with the use of OR gate giving inputs 'B' and 'C' we have got output of OR gate as 'X' and then 'A' and 'X' are given as inputs in NAND gate to get 'Y' as output.

#### A) OR GATE

Case I : B-low & C-low - X-low

→ As 'B' and 'C' both are low thus, both the PMOS will be OFF and both NMOS will be ON, In this case  $V_{out}$  will not be able to find any path to get connected between  $V_{out}$  to GND. Thus,  $V_{out}$  will be discharged, so low [logic 0].

Case II:- B-low & C-High - X-high.

→ B-low : NMOS2 OFF, PMOS2-ON. C-High : NMOS3-ON, PMOS3-OFF  
 Although PMOS3 is OFF, output will still get a path through PMOS2 to get connected with  $V_{dd}$ . NMOS2 and NMOS3 are in series, as NMOS2 is OFF so output will not be able to find path to GND to get discharged. So, High [logic 1].

Case III :- B-High & C-Low ... X-High

⇒ B-High : NMOS2-ON, PMOS2-OFF, C-Low : NMOS3-OFF, PMOS3-ON, the explanation is similar to Case II, output level will be High [Logic 1]

Case IV :- B-high & c-high ... X-High

⇒ As 'B' and 'C' both are high; thus both the PMOS will be ON and both the NMOS will be OFF. In this case  $V_{out}$  gets the path to connect with  $V_{dd}$ , And as both NMOS are OFF.  $V_{out}$  ~~does~~ does not get path to connect with GND to get discharged, so High [Logic 1].

## B) NAND GATE

Case I : A-Low & X-Low ... Y-High.

⇒ As 'A' and 'X' both are low; both the PMOS will be ON and both the NMOS will be OFF. So output ( $V_{out}$ ) will get two paths through two ON PMOS, to get connected with  $V_{dd}$ . Thus output will be charged to  $V_{dd}$  level. The output line will not get any path to the GND and both the NMOS are OFF. So there is no path through which the output line can discharge. The output line will ~~not~~ maintain voltage level at  $V_{dd}$ . So High [Logic 1].

Case II : A-Low & X-High ... Y-High

⇒ A-low : PMOS1-ON, NMOS1-OFF ; B-High : PMOSX-OFF, NMOSX-ON. PMOS1 and PMOSX are in parallel. Though PMOSX OFF, still output line will get a path through PMOS1 to get connected with  $V_{dd}$ . NMOS1 & NMOSX are in series as NMOS1 is OFF, so  $V_{out}$  will not be able to find a path to GND to get discharged. This in turn results

the  $V_{out}$  to be maintained as a level of  $V_{dd}$ . So High [Logic 1]

Case III :- A - High & X - low ... Y - High.

A-High: PMOS1-OFF, NMOS1-ON; X-low: PMOSX-ON, NMOSX-OFF

The explaination is similar to Case II,  $V_{out}$  level will be high [Logic 1]

Case IV :- A - High & X - High ... Y - low

A-High: PMOS1-OFF, NMOS1-ON; X-High: PMOSX-OFF, NMOSX-OFF.

In this case both the PMOS are OFF, so  $V_{out}$  will not find any path to get connected with  $V_{dd}$ . As both

NMOS are ON, the series connection of NMOS will create a path from  $V_{out}$  to GND. Since the path to ground is established  $V_{out}$  will be discharged. So low [Logic 0].

Result:- Thus, in this way we have studied, designed, ~~implemented~~ and simulated the layout of the Boolean expression using CMOS.



## Layout



Exp - 06.

Aim:- To write a verilog program for basic logic gates to synthesize and simulate using xilinx.

Software :- Xilinx ISE Design Suite.

Algorithm:-

- 1) Start the program.
- 2) Declare the input and output variables.
- 3) Declare the output as register data type.
- 4) Use PROCEDURAL construct statement for verilog code.
- 5) Write the functionality of the gates.
- 6) Terminal the program.

Theory - AND GATE in verilog is expressed as  $y = a \& b$

OR GATE in verilog is expressed as  $y = a | b$

NOT GATE in verilog is expressed as  $y = \sim a$

NAND GATE in verilog is expressed as  $y = \sim (a \& b)$

NOR GATE in verilog is expressed as  $y = \sim (a | b)$

Program:-

Module logic gates ( $a, b, o, p, q, r, s$ );

input a, b;

output o, p, q, r, s;

and ( $o, a, b$ );

or ( $p, a, b$ );

not ( $q, a$ );

## PROGRAM :-

Module all gate c  
input a,b,  
output o,p,q,r,s  
);

assign o = a & b; //and gate

assign p = a | b; //or gate

assign q = ~a; //not gate

assign r = ~(a & b); //nand gate

assign s = ~a △ b; //nor gate

end module

## Diagram:-

All logic gates



```
nand (u,a,b);  
nor (g,a,b);  
end module.
```

### Procedure :-

- 1] click on the xilinx ISE Design Suite or Xilinx project Navigator icon on the desktop.
- 2] Write the Verilog Code by choosing HDL as top level, source Module.
- 3] Check Syntax, view RTL Schematic and note the device Utilization Summary by double clicking on the Synthesis in the process window.
- 4] Perform the functional simulation using xilinx ISE Simulator.
- 5] The output waveform can be observed in ModelSim.

Result:- Thus the verilog program for basic logic gates were written synthesized and simulated using Xilinx.

Aim:- To write a verilog program for full adder to synthesize and simulate using Xilinx software tool.

Tool Required:- Xilinx ISE Design Suite Software.

- Algorithm:-
- ① Start the program.
  - ② Declare the input and output variables.
  - ③ Declare the output as register data type.
  - ④ Use PROCEDURAL construct statement for verilog code.
  - ⑤ Terminate the program.

Theory:-

Full Adder:- A Full Adder is a ~~series~~ combinational circuit that faces the arithmetic sums of three bits. It consists of 3 input and 2 output. The third input is the carry from the previous lower ~~sign~~ significant position. The two outputs are designated as sum (S) and carry (C). The binary present in the input and the output C=1 if two are three input are 1.

$$\text{Sum} = x \wedge y \wedge z$$

$$\text{Carry} = (x \& y) | (y \& z) | (x \& z)$$

Procedure:-

- ① Click on the Xilinx ISE Design suite or Xilinx Project Navigator icon on the desktop.
- ② Write the verilog code by choosing HDL at top level source module.

# FULL ADDER



- ③ Check Syntax, view RTL schematic and note the device utilization summary by double clicking on the synthesis in the process window.
- ④ Perform the functional simulation using Xilinx ISE simulator.
- ⑤ Output can be observed by using model sim.

Program:-

• Verilog code For Full Adder:-

module FULLADDER (

input a,

input b,

input Cin,

output d,

output e,

output f,

output sum,

output cout,

);

assign d = a ^ b;

assign e = d & cin;

assign f = a & b;

assign Sum = d ^ cin;

assign Cout = e | f;

end module.

Result:- Thus, verilog program for fulladder was written.  
Synthesized & Simulated using Xilinx tool.

## Exp.- 08.

Aim:- To write a verilog program for multiplexer to synthesize and simulate using xilinx software tools.

Tools required:- Xilinx ISE Design Suite 12.1 software

### Theory :-

Multiplexer is a combinational circuit that selects binary information from one of many input lines and directs it to a single output line. The set of selection of a particular line is controlled by selection line. Normally there are  $2^n$  input lines and n selection lines whose bit combinations determine which input is selected.

The 4:1 mux has four inputs  $I_0, I_1, I_2, I_3$  and select lines  $S_0$  and  $S_1$ , the select line  $S_0$  &  $S_1$ , are decoded to select a particular AND gate, the output of the AND gates are applied to a single OR gate that provides the one line output  $Y$ .

### Procedure :-

- ① Click on the Xilinx ISE Design Suite or Xilinx Project navigator icon on the desktop.
- ② Write Verilog code by choosing HDL as top level source module.
- ③ Check syntax, view RTL schematic in the process window and note device utilization summary by double clicking on the Synthesis in the process window.
- ④ Perform the functional simulation using Xilinx ISE Simulator.
- ⑤ The output can be observed using model simulation.



Program:-

• Verilog code for Multiplexer:-

```
module MULTIPLEXER
```

```
    input A,
```

```
    input B,
```

```
    input C,
```

```
    output D,
```

```
    output E,
```

```
    output Y
```

```
);
```

```
assign D = A & ~C;
```

```
assign E = B & C;
```

```
assign Y = D + E;
```

```
end module.
```

Result:- Thus, the verilog program for multiplexer we written, synthesized and simulated using Xilinx tool.

Verilog program for basic logic gates to synthesize & simulate

```
module demo1(
    input a,b,
    output o,p,q,r,s
);
assign o= a&b;//and gate
assign p= a|b; //or gate
assign q= ~a;//not gate
assign r= ~(a&b);//nand gate
assign s= ~a&b;//not gate
endmodule
```

Verilog program for full adder to synthesize and simulate

```
module fulladder(
    input a,
    input b,
    input cin,
    output d,
    output e,
    output f,
    output sum,
    output cout
);
assign d = a ^ b;
assign e = d & cin;
assign f = a & b;
assign sum = d^cin;
assign cout = e|f;
endmodule
```

VERILOG CODE for Multiplexer to synthesize

```
module multiplexer(
    input A,
    input B,
    input C,
    output D,
    output E,
    output Y
);
assign D = A&~C;
assign E = B&C;
assign F = D+E;
endmodule
```