Tag Archives: Technology

Generative AI Basics

Generative AI Basics: Understanding the Fundamentals

Generative AI, a subset of artificial intelligence (AI), has garnered significant attention in recent years due to its ability to create new content that mimics human creativity. From generating realistic images to composing music and even writing text, generative AI algorithms have made remarkable strides. But how does generative AI work, and what are the basic principles behind it? Let’s delve into the fundamentals.

What is Generative AI?

Generative AI refers to algorithms and models designed to generate new content, whether it’s images, text, audio, or other types of data. Unlike traditional AI systems that are primarily focused on specific tasks like classification or prediction, generative AI aims to create entirely new data that resembles the input data it was trained on.

Key Components of Generative AI:

  1. Generative Models: At the heart of generative AI are generative models. These models learn the underlying patterns and structures of the input data and use this knowledge to generate new content. Some of the popular generative models include Generative Adversarial Networks (GANs), Variational Autoencoders (VAEs), and Autoregressive Models.
  2. Training Data: Generative models require large datasets for training. These datasets can include images, text, audio, or any other type of data that the model aims to generate. The quality and diversity of the training data significantly impact the performance of the generative model.
  3. Loss Functions: Loss functions are used to quantify how well the generative model is performing. They measure the difference between the generated output and the real data. By minimizing this difference during training, the model learns to produce outputs that are more similar to the real data.
  4. Sampling Techniques: Once trained, generative models use sampling techniques to generate new data. These techniques can vary depending on the type of model and the nature of the data. For instance, in image generation, random noise may be fed into the model, while in text generation, the model may start with a prompt and generate the rest of the text.

Common Generative AI Applications:

  1. Image Generation: Generative models like GANs have been incredibly successful in generating high-quality, realistic images. These models have applications in generating artwork, creating realistic avatars, and even generating photorealistic images of objects that don’t exist in the real world.
  2. Text Generation: Natural Language Processing (NLP) models such as GPT (Generative Pre-trained Transformer) are proficient in generating human-like text. They can be used for tasks like content generation, dialogue systems, and language translation.
  3. Music and Audio Generation: Generative models have also been used to create music and audio. These models can compose music in various styles, generate sound effects, and even synthesize human speech.
  4. Data Augmentation: Generative models can also be used for data augmentation, where new training samples are generated to increase the diversity of the dataset. This helps improve the performance of machine learning models trained on limited data.

Challenges and Ethical Considerations:

While generative AI has opened up exciting possibilities, it also presents several challenges and ethical considerations:

  1. Bias and Fairness: Generative models can inadvertently perpetuate biases present in the training data. Ensuring fairness and mitigating biases in generated outputs is a significant concern.
  2. Misuse and Manipulation: There’s a risk of generative AI being used for malicious purposes such as creating fake news, generating deepfake videos, or impersonating individuals.
  3. Quality Control: Assessing the quality and authenticity of generated content can be challenging, particularly in applications like image and video generation where the line between real and generated content may blur.
  4. Data Privacy: Generative models trained on sensitive data may raise concerns about data privacy and security, especially if the generated outputs contain identifiable information.

Conclusion:

Generative AI holds immense promise in various domains, revolutionizing how we create and interact with digital content. Understanding the basics of generative AI empowers us to harness its potential while also being mindful of its limitations and ethical implications. As research in this field progresses, we can expect even more innovative applications and advancements in generative AI technology.

Script to Create Foreign Key on the Compound Primary Key

Compound Primary key is a primary key which is created on more than one column. Now the questions is how to create the foreign key for the compound primary key where it references more than one column.

Check the below example.

create table employee
(
	empID int not null,
	SSN int not null,
	name varchar(20)
)


ALTER TABLE [employee]
ADD CONSTRAINT pk_employee PRIMARY KEY (empID, SSN)


create table EmpDetail
(
		empID int,
		SSN int,
		address varchar(20),
		city varchar(20),
		pin varchar(20)
)

ALTER TABLE dbo.empDetail
   ADD CONSTRAINT FK_Employee
   FOREIGN KEY(empID, SSN)
   REFERENCES dbo.employee(empID, SSN)


SELECT
    tc.TABLE_NAME,
    tc.CONSTRAINT_NAME, 
    ccu.COLUMN_NAME
FROM 
    INFORMATION_SCHEMA.TABLE_CONSTRAINTS tc
INNER JOIN 
    INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE ccu 
      ON ccu.TABLE_NAME = tc.TABLE_NAME AND ccu.CONSTRAINT_NAME = tc.CONSTRAINT_NAME
WHERE
    tc.TABLE_NAME IN ('employee','employeeDetail')

Primary Key, Unique Key Constraints – Clustered Index and Non Clustered Index

You can use the below script to create the Primary Key on the already existing tables. Primary key enforces a uniqueness in the column and created the clustered index as default.

Primary key will not allow NULL values.

-- Adding the NON NULL constraint
ALTER TABLE [TableName]	 
ALTER COLUMN PK_ColumnName int NOT NULL

--Script to add the primary key on the existing table
ALTER TABLE [TableName]
ADD CONSTRAINT pk_ConstraintName PRIMARY KEY (PK_ColumnName)

If you want to define or create the non-clustered index on the existing table, you can use the below script. If the data in the column is unique, you can create the Unique Constraint as well.

Unique Key enforces uniqueness of the column on which they are defined. Unique Key creates a non-clustered index on the column. Unique Key allows only one NULL Value.

--script to create non-clustered Index
create index IX_ColumName on TableName(ColumnName)
--script to create Unique constraint on the existing table
ALTER TABLE TableName ADD CONSTRAINT ConstraintName UNIQUE(ColumnName)

How to insert value into IDENTITY column?

If you will try to insert the value into Identity column you will get the one of the below error.

Error 1:
Msg 544, Level 16, State 1, Line 1
Cannot insert explicit value for identity column in table ‘Employee’ when IDENTITY_INSERT is set to OFF.

Error 2:
Error 8101 An explicit value for the identity column in table can only be specified when a column list is used and IDENTITY_INSERT is ON

Solution:
Write SET IDENTITY_INSERT table name ON before the insert script and SET IDENTITY_INSERT table name Off after insert script.

Example,

use db1

create table Employee
(
	myID int identity(100,1),
	name varchar(20)
)

insert into Employee(name) values('Jugal')

--if i will try to insert the value into Identity column it will fail
insert into Employee(myID,name) values (101,'DJ')

--you can add the data into identiy column by turning on the IDENTITY_INSERT ON

SET IDENTITY_INSERT Employee ON
	insert into Employee(myID,name) values (101,'DJ')
SET IDENTITY_INSERT Employee OFF